# IC Compiler<sup>™</sup> Classic Router User Guide

Version H-2013.03, March 2013

SYNOPSYS®

# **Copyright Notice and Proprietary Information**

Copyright © 2013 Synopsys, Inc. All rights reserved. This software and documentation contain confidential and proprietary information that is the property of Synopsys, Inc. The software and documentation are furnished under a license agreement and may be used or copied only in accordance with the terms of the license agreement. No part of the software and documentation may be reproduced, transmitted, or translated, in any form or by any means, electronic, mechanical, manual, optical, or otherwise, without prior written permission of Synopsys, Inc., or as expressly provided by the license agreement.

#### **Destination Control Statement**

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

#### **Disclaimer**

SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

#### **Trademarks**

Synopsys and certain Synopsys product names are trademarks of Synopsys, as set forth at http://www.synopsys.com/Company/Pages/Trademarks.aspx.

All other product or company names may be trademarks of their respective owners.

Synopsys, Inc. 700 E. Middlefield Road Mountain View, CA 94043 www.synopsys.com

#### Copyright Statement for the Command-Line Editing Feature

Copyright © 1992, 1993 The Regents of the University of California. All rights reserved. This code is derived from software contributed to Berkeley by Christos Zoulas of Cornell University.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

- 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer
- 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
- 3. All advertising materials mentioning features or use of this software must display the following acknowledgement: This product includes software developed by the University of California, Berkeley and its contributors.
- 4. Neither the name of the University nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

#### Copyright Statement for the Line-Editing Library

Copyright © 1992 Simmule Turner and Rich Salz. All rights reserved.

This software is not subject to any license of the American Telephone and Telegraph Company or of the Regents of the University of California.

Permission is granted to anyone to use this software for any purpose on any computer system, and to alter it and redistribute it freely, subject to the following restrictions:

- 1. The authors are not responsible for the consequences of use of this software, no matter how awful, even if they arise from flaws in it.
- 2. The origin of this software must not be misrepresented, either by explicit claim or by omission. Since few users ever read sources, credits must appear in the documentation.
- 3. Altered versions must be plainly marked as such, and must not be misrepresented as being the original software. Since few users ever read sources, credits must appear in the documentation.
- 4. This notice may not be removed or altered.

|    | About This Guide                                                  | x           |
|----|-------------------------------------------------------------------|-------------|
|    | Customer Support                                                  | xiii        |
| 1. | Introduction to the Classic Router                                |             |
|    | Basic Routing Flow                                                | 1-2         |
|    | Prerequisites for Routing                                         | 1-3         |
|    | Checking Routability                                              | 1-3         |
| 2. | Setting Up for Routing                                            |             |
|    | Enabling the Classic Router                                       | 2-2         |
|    | Specifying Route Guides                                           | 2-3         |
|    | Defining Routing Blockages                                        | 2-5         |
|    | Setting the Preferred Routing Direction                           | 2-6         |
|    | Using Nondefault Routing Rules  Defining Nondefault Routing Rules | 2-7<br>2-7  |
|    | Applying Nondefault Routing Rules                                 | 2-8         |
|    | Applying Nondefault Routing Rules to Clock Nets                   | 2-9         |
|    | Applying Nondefault Routing Rules to Signal Nets                  | 2-9<br>2-10 |
|    | Specifying the Routing Layers                                     | 2-11        |
|    | Specifying the Ignored Layers                                     | 2-11        |
|    | Specifying Routing Layers for Specific Nets                       | 2-12        |

|    | Setting Routing Types                                                                                                                                                                                                                                                                                                                 | 2-13                                                         |
|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|
|    | Setting Routing Options                                                                                                                                                                                                                                                                                                               | 2-13                                                         |
|    | Setting Signal Integrity Options                                                                                                                                                                                                                                                                                                      | 2-17<br>2-17<br>2-18                                         |
|    | Enabling Distributed Routing                                                                                                                                                                                                                                                                                                          | 2-18<br>2-20<br>2-22<br>2-22                                 |
| 3. | Routing Clock and Signal Nets                                                                                                                                                                                                                                                                                                         |                                                              |
|    | Routing Critical NetsShielding Clock Nets                                                                                                                                                                                                                                                                                             | 3-2<br>3-3                                                   |
|    | Routing Signal Nets  Routing Signal Nets by Using the route_opt Command  Setting the Routing and Optimization Strategy  Enabling Fixing of Hold Time Violations  Setting the Crosstalk Reduction Options  Using Scenario Compression for Multicorner-Multimode Designs  Running the route_opt Command.  Performing Focal Optimization | 3-4<br>3-5<br>3-6<br>3-8<br>3-10<br>3-17                     |
|    | Performing Final Stage Leakage-Power Recovery Routing Signal Nets by Using Automatic Routing Running Individual Routing Steps Global Routing Track Assignment Detail Routing Search and Repair Wire and Via Optimization  Analyzing Congestion Generating a Congestion Report                                                         | 3-20<br>3-22<br>3-23<br>3-24<br>3-25<br>3-26<br>3-27<br>3-27 |
|    | Generating a Congestion Map                                                                                                                                                                                                                                                                                                           | 3-30<br>3-32                                                 |
|    | Performing ECO Routing                                                                                                                                                                                                                                                                                                                | 3-34                                                         |
|    | Reporting Cell Placement and Routing Statistics                                                                                                                                                                                                                                                                                       | 3-34                                                         |
|    | NEDULLING OCIL FLACCITICAL AND MOULING STALLSHOS                                                                                                                                                                                                                                                                                      | ა-აე                                                         |

|    | Verifying the Routed Design                                              |
|----|--------------------------------------------------------------------------|
|    | Using the signoff_drc Command                                            |
|    | Setting Up the Validation Tool Environment                               |
|    | Setting Up the Physical Signoff Options                                  |
|    | Running the signoff_drc Command                                          |
|    | Using the verify_drc Command                                             |
|    | Using the verify_route Command                                           |
|    | Using the Calibre Interface                                              |
|    | Analyzing DRC Violations                                                 |
|    | Using the DRC Query Commands                                             |
|    | Using the Error Browser                                                  |
| 4. | Using the Classic Router for Design for Manufacturing and Chip Finishing |
|    | Preventing Antenna Problems                                              |
|    | Setting the Antenna Mode                                                 |
|    | Defining Antenna Rules                                                   |
|    | Basic Antenna Rules                                                      |
|    | Advanced Antenna Rules                                                   |
|    | Reporting Antenna Rules                                                  |
|    | Removing Antenna Rules                                                   |
|    | Checking Antenna Rules                                                   |
|    | Specifying Antenna Properties                                            |
|    | Fixing Antenna Violations                                                |
|    | Running Search and Repair                                                |
|    | Inserting Diodes                                                         |
|    | Connecting Spare Diodes                                                  |
|    | Setting Detail Route Options to Control Antenna Fixing                   |
|    | Reducing Critical Areas                                                  |
|    | Reporting Critical Areas                                                 |
|    | Displaying Critical Area Maps                                            |
|    | Performing Wire Spreading                                                |
|    | Performing Wire Widening                                                 |
|    | Inserting Redundant Vias                                                 |
|    | Inserting Filler Cells                                                   |
|    | Inserting Standard Cell Fillers                                          |
|    | Defining the Filler Rules                                                |
|    | Inserting Filler Cells                                                   |

| Removing Filler Cells                      | 4-32 |
|--------------------------------------------|------|
| Reporting Filler Cells                     | 4-32 |
| Inserting End Caps                         | 4-33 |
| Inserting Well Fillers                     | 4-34 |
| Inserting Pad Fillers                      | 4-36 |
| Inserting Metal Fill                       | 4-37 |
| IC Compiler Metal Fill                     | 4-38 |
| Signoff Metal Fill                         | 4-40 |
| Setting Up the Validation Tool Environment | 4-40 |
| Setting Up the Physical Signoff Options    | 4-41 |
| Setting Up Distributed Processing          | 4-41 |
| Running the signoff_metal_fill Command     | 4-43 |
| Performing Notch and Gap Filling           | 4-49 |
| Lithography Compliance Checking            | 4-50 |
| Detecting LCC Hotspots                     | 4-50 |
| Fixing LCC Hotspots                        | 4-52 |

Index

# Preface

This preface includes the following sections:

- About This Guide
- Customer Support

#### **About This Guide**

The Synopsys IC Compiler™ tool provides a complete netlist-to-GDSII or netlist-to-clock-tree-synthesis design solution, which combines proprietary design planning, physical synthesis, clock tree synthesis, and routing for logical and physical design implementations throughout the design flow.

This guide describes the usage of the classic router in the IC Compiler implementation and integration flow. The flow is described in the IC Compiler Implementation User Guide, which also describes the usage of Zroute in the flow. For information about defining the routing design rules, see the IC Compiler Technology File and Routing Rules Reference Manual.

#### **Audience**

This user guide is for design engineers who use the IC Compiler tool to implement designs.

To use the IC Compiler tool, you need to be skilled in physical design and design synthesis and be familiar with the following:

- Physical design principles
- The Linux or UNIX operating system
- The tool command language (Tcl)

#### **Related Publications**

For additional information about the IC Compiler tool, see the documentation on SolvNet at the following address:

https://solvnet.synopsys.com/DocsOnWeb

You might also want to see the documentation for the following related Synopsys products:

- Design Compiler<sup>®</sup>
- Milkyway Environment™
- IC Validator
- Hercules<sup>™</sup>

#### **Release Notes**

Information about new features, changes, enhancements, known limitations, and resolved Synopsys Technical Action Requests (STARs) is available in the *IC Compiler Release Notes* in SolvNet.

To see the IC Compiler Release Notes,

- Go to the Download Center on SolvNet located at the following address: https://solvnet.synopsys.com/DownloadCenter
- 2. Select IC Compiler, and then select a release in the list that appears.

# **Conventions**

The following conventions are used in Synopsys documentation.

| Convention     | Description                                                                              |
|----------------|------------------------------------------------------------------------------------------|
| Courier        | Indicates syntax, such as write_file.                                                    |
| Courier italic | Indicates a user-defined value in syntax, such as write_file <code>design_list</code> .  |
| Courier bold   | Indicates user input—text you type verbatim—in examples, such as                         |
|                | <pre>prompt&gt; write_file top</pre>                                                     |
| []             | Denotes optional arguments in syntax, such as write_file [-format fmt]                   |
|                | Indicates that arguments can be repeated as many times as needed, such as pin1 pin2 pinN |
| 1              | Indicates a choice among alternatives, such as low   medium   high                       |
| Ctrl+C         | Indicates a keyboard combination, such as holding down the Ctrl key and pressing C.      |
| \              | Indicates a continuation of a command line.                                              |
| 1              | Indicates levels of directory structure.                                                 |
| Edit > Copy    | Indicates a path to a menu command, such as opening the Edit menu and choosing Copy.     |

# **Customer Support**

Customer support is available through SolvNet online customer support and through contacting the Synopsys Technical Support Center.

#### **Accessing SolvNet**

SolvNet includes a knowledge base of technical articles and answers to frequently asked questions about Synopsys tools. SolvNet also gives you access to a wide range of Synopsys online services including software downloads, documentation, and technical support.

To access SolvNet, go to the following address:

https://solvnet.synopsys.com

If prompted, enter your user name and password. If you do not have a Synopsys user name and password, follow the instructions to register with SolvNet.

If you need help using SolvNet, click HELP in the top-right menu bar.

#### **Contacting the Synopsys Technical Support Center**

If you have problems, questions, or suggestions, you can contact the Synopsys Technical Support Center in the following ways:

- Open a support case to your local support center online by signing in to SolvNet at https://solvnet.synopsys.com, clicking Support, and then clicking "Open A Support Case."
- Send an e-mail message to your local support center.
  - o E-mail support\_center@synopsys.com from within North America.
  - Find other local support center e-mail addresses at http://www.synopsys.com/Support/GlobalSupportCenters/Pages
- Telephone your local support center.
  - o Call (800) 245-8005 from within North America.
  - Find other local support center telephone numbers at http://www.synopsys.com/Support/GlobalSupportCenters/Pages

1

# Introduction to the Classic Router

The classic router is the original IC Compiler router and can be used for technology nodes at or above 45 nm. It is the router in the IC Compiler-XP package and is an optional router in the IC Compiler, IC Compiler-DP, and IC Compiler-PC packages.

#### Note:

Use either the classic router or Zroute to route your design; do not mix the use of routers in your design flow. Although running Zroute on your design is possible after running the classic router, you should not run the classic router on your design after using Zroute. If you run the classic router after Zroute, the tool issues the following message:

```
Error: It is not recommended to use classic router commands after Zroute commands. (RT-302)
```

To check which router was used on your design, use the <code>is\_zrt\_routed\_design</code> command, which returns <code>false</code> if the design was routed with the classic router and <code>true</code> if the design was routed with Zroute.

This chapter contains the following sections:

- Basic Routing Flow
- Prerequisites for Routing
- Checking Routability

# **Basic Routing Flow**

Figure 1-1 shows the basic routing flow, which includes clock routing, signal routing, chip finishing and DFM optimizations, and route verification.

Figure 1-1 Basic Routing Flow



# **Prerequisites for Routing**

Before you can perform routing, your design must meet the following conditions:

- Power and ground nets have been routed after design planning and before placement.
   For more information, see the IC Compiler Design Planning User Guide.
- Clock tree synthesis and optimization have been performed.
   For more information, see Chapter 5, "Clock Tree Synthesis," in the IC Compiler Implementation User Guide.
- Estimated congestion is acceptable.
- Estimated timing is acceptable (about 0 ns of slack).
- Estimated maximum capacitance and transition have no violations.

To verify that your design meets the last three prerequisites, you can check the routability of its placement as explained in the following section, "Checking Routability."

# **Checking Routability**

After placement is completed, you can have the tool check whether your design is ready for detail routing. The tool checks pin access points, cell instance wire tracks, pins out of boundaries, minimum grid and pin design rules, and blockages to make sure they meet design requirements. It creates an error file named after the top cell in your design (top\_cell\_name.err), with a list of violations that you should correct before performing detail routing.

To verify that your design is ready for detail routing, use the <code>check\_routeability</code> command (or choose Route > Check Routability in the GUI).

After you run the <code>check\_routeability</code> command, you can use the <code>report\_error\_coordinates</code> command to report the location of each error. You can also use the error browser to examine the errors in the GUI. For more information about the error browser, see the "Examining Routing and Verification Errors" section in Appendix A of the <code>IC Compiler Implementation User Guide</code> and the "Examining Routing and Verification Errors" topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

# 2

# Setting Up for Routing

This chapter describes the setup tasks you must complete before running classic router commands. It contains the following sections:

- Enabling the Classic Router
- Specifying Route Guides
- Defining Routing Blockages
- Setting the Preferred Routing Direction
- Using Nondefault Routing Rules
- Specifying the Routing Layers
- Setting Routing Types
- Setting Routing Options
- Setting Signal Integrity Options
- Enabling Distributed Routing

# **Enabling the Classic Router**

To enable the classic router, set the Zroute route mode option to false. The setting for the Zroute mode option is saved in the Milkyway design database.

If you are using the command line, enter the following command:

```
icc_shell> set_route_mode_options -zroute false
```

If you are using the GUI, deselect Zroute Mode in either the Route or Finishing menu, as shown in Figure 2-1.

Figure 2-1 Enabling the Classic Router in the GUI



#### Note:

If you are using the IC Compiler-XP package, the classic router is the default router. You do not need to enable it explicitly.

When you enable the classic router, the following commands use the classic router instead of Zroute:

- estimate fp area
- report congestion
- place\_opt -congestion (when the placer\_enable\_enhanced\_router variable is true)
- create\_placement -congestion (when the placer\_enable\_enhanced\_router variable is true)
- clock\_opt
- route\_opt
- optimize\_clock\_tree (when run on a postroute design)
- signoff\_opt

#### Note:

In addition to these commands that can use either Zroute or the classic router, there are several commands that are specific to the classic router.

# **Specifying Route Guides**

You can create or remove route guides that do the following for a specific area of your design:

- Prevent routing for signal or prerouted nets, either completely or partially
- Change the wiring direction
- Control wiring density
- Fix violations

#### Note:

The blockage, pin, and via (BPV) extraction process also creates route guides. For more information about creating route guides during BPV, see the *Library Data Preparation for IC Compiler User Guide*.

To create a route guide, use the <code>create\_route\_guide</code> command (or choose Floorplan > Create Route Guide in the GUI). Table 2-1 defines the <code>create\_route\_guide</code> options. For more information about these options, see the man page.

Table 2-1 create\_route\_guide Command Options

| Command option                                                                                 | Description                                                               |
|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| -name name (Name box in the GUI)                                                               | Specifies the name of the route guide.                                    |
| -repair_as_single_sbox ("Repair as single SBox" check box in the GUI)                          | Enables fixing of violations.                                             |
| -no_signal_layers layers  ("No signal route on layers" check box and list in the GUI)          | Prevents the routing of signal wires on the specified layers.             |
| -zero_min_spacing ("Zero min-spacing" check box in the GUI)                                    | Allows the routing of wires within the keepout margin of the route guide. |
| -no_preroute_layers layers  ("No automatic preroutes on layers" check box and list in the GUI) | Prevents automatic preroutes on the specified layers.                     |

Table 2-1 create\_route\_guide Command Options (Continued)

| Command option                                                                                                 | Description                                                                                                                                                                                                                                                      |
|----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -preferred_direction_only_layers layers ("Layers with preferred direction only" check box and list in the GUI) | Specifies the layers that must be routed in the preferred direction.                                                                                                                                                                                             |
| -horizontal_track_utilization percentage (Horizontal box in "Route track utilization" section in the GUI)      | Specifies the allowable horizontal track utilization.                                                                                                                                                                                                            |
| -vertical_track_utilization percentage (Vertical box in "Route track utilization" section in the GUI)          | Specifies the allowable vertical track utilization.                                                                                                                                                                                                              |
| -coordinate rectangle                                                                                          | Specifies the coordinates for the route guide.                                                                                                                                                                                                                   |
| (Coordinates box in the GUI)                                                                                   | In the GUI, you can type the coordinates in the dialog box or draw the rectangle in the layout view. You can also specify that the route guide should snap to the minimum grid, placement site, routing track (the default), middle routing track, or user grid. |
|                                                                                                                | From the command line, the snapping is controlled by the set_object_snap_type command.                                                                                                                                                                           |
| -switch_preferred_direction                                                                                    | Switches the preferred wiring direction.                                                                                                                                                                                                                         |
| ("Switch preferred direction" check box in the GUI)                                                            |                                                                                                                                                                                                                                                                  |

#### Note:

The classic router does not support the  $-single_layer_routing$  option. If you specify this option, the classic router ignores it.

To find route guides, use the  $get\_route\_guides$  command. For example, to get all the route guides in your design, enter

```
icc_shell> get_route_guides *
```

You can also find route guides by using a filter expression (-filter expression) or by using rectangular areas that encompass (-within  $\{x1\ y1\}\ \{x2\ y2\}\}$ ) or touch (-touch  $\{x1\ y1\}\ \{x2\ y2\}\}$ ) the guides.

To remove route guides, use the remove\_route\_guide command. You can remove a collection of route guides, such as that returned by the get\_route\_guides command; all route guides (-all); or a specific named route guide (-name).

For more information about the <code>get\_route\_guides</code> or <code>remove\_route\_guide</code> command, see the man page.

# **Defining Routing Blockages**

A routing blockage defines a region where no routing is allowed on a specific layer. You define routing blockages by using the <code>create\_routing\_blockage</code> command. To define a routing blockage, you must specify

· The blockage layers to which the routing blockage applies

Use the <code>-layers</code> option to specify the blockage layers. Valid values for the blockage layers are metal1Blockage-metal15Blockage, via1Blockage-via14Blockage, polyBlockage, and polyContBlockage. To query the Milkyway design library for the blockage layers, use the <code>get\_layers -include\_system</code> command.

You can specify one or more blockage layers. If the routing blockage is defined on a metal blockage layer, it is a metal routing blockage. If the routing blockage is defined on a via blockage layer, it is a via routing blockage.

• The region of the blockage

Use the -bbox option to specify the region for a rectangular routing blockage. Use the -boundary option to specify the region for a rectilinear routing blockage.

For example, to create rectangular routing blockages on the metal1 and via1 blockage layers, enter the following command:

```
icc_shell> create_routing_blockage \
   -layers {metallBlockage vialBlockage} -bbox {x1 y1 x2 y2}
```

When the tool creates routing blockages, it assigns a name of RB\_id to each routing blockage.

To find routing blockages, use the <code>get\_routing\_blockages</code> command. For example, to get all the routing blockages in your design, enter

```
icc shell> get routing blockages *
```

You can also find routing blockages by using a filter expression (-filter expression) or by using rectangular areas that encompass (-within  $\{x1\ y1\}\ \{x2\ y2\}\}$ ) or touch (-touch  $\{\{x1\ y1\}\ \{x2\ y2\}\}$ ) the blockages.

To remove routing blockages, use the remove\_routing\_blockage command.

# **Setting the Preferred Routing Direction**

Use the set\_preferred\_routing\_direction command to reset and override the default preferred routing direction specified in the library or the design for a specific layer. The layer direction set with this command applies to the current design only.

#### The command syntax is

```
set_preferred_routing_direction
   -layers list_of_layers
   -direction horizontal | vertical
```

For example, to set the preferred routing direction to vertical for layer M5 and M7, enter

```
icc_shell> set_preferred_routing_direction -layers "M5 M7" \
    -direction vertical
```

#### Note:

Settings made with the <code>create\_route\_guide -switch\_preferred\_direction</code> command, which changes the preferred direction within the area that is covered by the route guide, override the settings made with the <code>set\_preferred\_routing\_direction</code> command.

Use the report\_preferred\_routing\_direction command to report the preferred routing direction for all the routing layers. The report lists the library and user-defined routing directions, as well as the direction that the tool will use. Example 2-1 shows an example report.

#### Example 2-1 Preferred Direction Report

```
*********
 Report : Layers
 Design : core_chip
 Version: Y-2006.06
 Date : Thu Mar 23 03:43:06 2006
*********
                                       Design Tool understands
Not Set Horizontal
       Layer Name Library metall Horizontal
       metal2
                       Vertical
                                        Not Set
                                                          Vertical
              Horizontal Not Set
Vertical Not Set
Horizontal Vertical
Vertical
       metal3
                                        Not Set
                                                           Horizontal
       metal4
                                                           Vertical
       metal5
                                                           Vertical
       metal6
                                                           Vertical
```

Use the remove\_preferred\_routing\_direction command to remove the user-defined directions for a specific layer from the design.

#### The command syntax is

```
remove_preferred_routing_direction -layers list_of_layers
```

# **Using Nondefault Routing Rules**

The classic router supports the use of nondefault routing rules, both for routing and for shielding. Before you can use a nondefault routing rule, you must define it. The following sections describe how to define and apply nondefault routing rules.

# **Defining Nondefault Routing Rules**

You define nondefault routing rules for specific nets by using the <code>define\_routing\_rule</code> command (or by choosing Route > Routing Setup > Define Routing Rule in the GUI). These rules define wire width and spacing rules and via types. Table 2-2 defines the <code>define\_routing\_rule</code> options. For more information about these options, see the man page.

Table 2-2 define\_routing\_rule Command Options

| Command option                                                                 | Description                                                                                                                                           |  |
|--------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| rule_name ("Rule name" box in the GUI)                                         | Specifies the name of the rule. This argument is required.                                                                                            |  |
| -reference_rule_name -default_reference_rule ("Reference rule" box in the GUI) | Specifies the name of the reference rule. This option is required.                                                                                    |  |
| -taper_level ("Taper level" box in the GUI)                                    | Specifies the tapering level.  The default tapering level is 0.                                                                                       |  |
| -taper_distance ("Taper distance" in the GUI)                                  | This option is not used by the classic router.  To specify the tapering distance for the classic router, use the droute_pinTaperLengthLimit variable. |  |
| -multiplier_width ("Width multiplier" box in the GUI)                          | Specifies the layer width multiplier.                                                                                                                 |  |
| -multiplier_spacing ("Spacing Multiplier" box in the GUI)                      | Specifies the layer spacing multiplier.                                                                                                               |  |
| -shield<br>("Specify shielding" check box in the<br>GUI)                       | Defines shielding with default spacing and default width.                                                                                             |  |

Table 2-2 define\_routing\_rule Command Options (Continued)

| Command option                                      | Description                                                                                                                                                                                                                        |  |
|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| -snap_to_track                                      | Snaps shielding wires to the track when selected.                                                                                                                                                                                  |  |
| ("Snap shielding to track" check box in the GUI)    | By default, snapping is not enabled.                                                                                                                                                                                               |  |
| -widths                                             | Specifies the width and spacing rules. You can specify only a single width and spacing rule per layer.                                                                                                                             |  |
| -spacings<br>-shield_widths                         | If you select "Specify shielding," the Width and Spacing columns in the "Metal table" section in the GUI refer to                                                                                                                  |  |
| -shield_spacings ("Metal table" section in the GUI) | shield width and shield spacing; otherwise, they refer to wire width and wire spacing.                                                                                                                                             |  |
| -via_cuts<br>("Via table" section in the GUI)       | Specifies the via types for the nondefault routing rule. You can specify only a single via type per layer.                                                                                                                         |  |
| -cuts<br>("Cut table" section in the GUI)           | Specifies the general cut definitions for the nondefault routing rule. The tool automatically selects the via types based on the cut definition and the technology file. The classic router uses only the first selected via type. |  |

For example, to define a nondefault routing rule named new\_rule that uses the default routing rule as the reference rule and defines nondefault width and spacing rules for metal1 and metal4, enter the following command:

```
icc_shell> define_routing_rule new_rule -default_reference_rule \
   -widths {m1 0.8 m4 0.9} -spacings {m1 1.0 m4 1.0}
```

# **Applying Nondefault Routing Rules**

The IC Compiler tool provides two commands for assigning nondefault routing rules to nets:

- set\_clock\_tree\_options
  - This command assigns nondefault routing rules to clock nets before clock tree synthesis.
- set\_net\_routing\_rule

This command assigns nondefault routing rules to signal nets and to clock nets after clock tree synthesis.

#### **Applying Nondefault Routing Rules to Clock Nets**

To assign a nondefault routing rule to clock nets, use the -routing\_rule option of the set\_clock\_tree\_options command.

#### Note:

This command works only before clock tree synthesis. If the clock tree has already been synthesized, use the set\_net\_routing\_rule command to apply the nondefault routing rules, as described in "Applying Nondefault Routing Rules to Signal Nets" on page 2-9.

For example, to assign a shielding rule called shield\_rule to the nets in the CLK clock tree before clock tree synthesis, enter the following command:

```
icc_shell> set_clock_tree_options -clock_trees CLK \
    -routing_rule shield_rule
```

By default, the shielding rule applies to all nets in the clock tree. To use the default routing rule for the nets closest to the sink pin, use the <code>-use\_default\_routing\_for\_sinks</code> option. The default routing rules are used for the specified number of clock tree levels closest to the clock sink. For more information about the <code>set\_clock\_tree\_options</code> command, see Chapter 5, "Clock Tree Synthesis," in the *IC Compiler Implementation User Guide*.

#### **Applying Nondefault Routing Rules to Signal Nets**

To apply a nondefault routing rule to one or more nets, use the  $set_net_routing_rule$  command (or choose Route > Routing Setup > Set Net Routing Rule in the GUI). Table 2-3 defines the  $set_net_routing_rule$  options. For more information about these options, see the man page.

Table 2-3 set\_net\_routing\_rule Command Options

| Command option                                                                   | Description                                                                   |
|----------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| list_of_nets (Nets box in the GUI)                                               | Specifies the nets to which to apply the rule. This argument is required.     |
| -rule rule_name ("Routing rule" box in the GUI)                                  | Specifies the name of the nondefault rule to apply.  This option is required. |
| -top_layer_probe AnyPort   OutPort   AllPort  ("Top layer probe mode" box in the | Specifies which ports to use for top-layer probing.  The default is AnyPort.  |

Table 2-3 set\_net\_routing\_rule Command Options (Continued)

| Command option                                                               | Description                                                                                                                                                                                                              |  |
|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| -reroute normal   minorchange   freeze ("Net re-routability" box in the GUI) | Specifies when to reroute nets.  The default is normal.                                                                                                                                                                  |  |
| -timing_driven_spacing ("Timing driven spacing" check box in the GUI)        | When timing-driven spacing is enabled, the router adds space between critical nets and nets that are parallel to them to reduce the intralayer coupling capacitances.  By default, timing-driven spacing is not enabled. |  |

#### **Reporting Nondefault Routing Rules**

To report the nondefault routing rules for specific nets, use the report\_net\_routing\_rules command.

```
icc_shell> report_net_routing_rules [get_nets *]
```

To output a Tcl script that contains the <code>define\_routing\_rule</code> commands used to define the nondefault routing rules for the specified nets, use the <code>-output</code> option when you run the <code>report\_net\_routing\_rules</code> command.

The name of the nondefault routing rule for a net is stored in the <code>var\_route\_rule</code> net attribute. You can access the value of this attribute by using the <code>get\_attribute</code> command.

To report the design-specific nondefault routing rules defined by the define\_routing\_rule command, use the report\_routing\_rules command. By default, this command reports all of the nondefault routing rules for the current design. To limit the report to a specific nondefault routing rule, specify the rule name as an argument to the command.

```
icc_shell> report_routing_rules rule_name
```

To output a Tcl script that contains the define\_routing\_rule commands used to define the specified nondefault routing rule or all nondefault routing rules for the design if you do not specify a routing rule, use the -output option when you run the report routing rules command.

# **Specifying the Routing Layers**

The IC Compiler tool lets you specify which layers can be ignored for routing and which layers are to be ignored for RC and congestion estimation. You can also specify the routing layers to use for specific nets (net layer constraints).

By default, when you set a maximum routing layer, it is a hard constraint. You can change it to a soft constraint or you can allow the use of higher layers only for pin connections by setting the hardMaxLayerConx detail route option. This option applies to both ignored layers (set\_ignored\_layers command) and net layer constraints (set\_net\_routing\_layer\_constraints command).

By default, when you set a minimum routing layer, it is a soft constraint. You can change it to a hard constraint or you can allow the use of lower layers only for pin connections by setting the hardMinLayerConx detail route option. This option applies to both ignored layers (set\_ignored\_layers command) and net layer constraints (set\_net\_routing\_layer\_constraints command).

#### **Specifying the Ignored Layers**

To specify the ignored layers, use the set\_ignored\_layers command (or choose Route > Routing Setup > Set Ignored Layers in the GUI). By default, RC estimation and congestion analysis use the same layers as routing.

To specify the minimum and maximum routing layers, use the <code>-min\_routing\_layer</code> and <code>-max\_routing\_layer</code> options, respectively. If you use only these options, the same layers are used for routing, RC estimation, and congestion analysis. For example, to use layers M2 through M7 for routing, RC estimation, and congestion analysis, use the following command:

```
icc_shell> set_ignored_layers \
    -min_routing_layer M2 -max_routing_layer M7
```

To use fewer layers for RC estimation and congestion analysis than those used for routing, use the <code>-rc\_congestion\_ignored\_layers</code> option to specify the layers to be ignored for RC estimation and congestion analysis. For example, to use layers M2 through M7 for routing and layers M3 through M7 for RC estimation and congestion analysis, use the following command:

```
icc_shell> set_ignored_layers \
   -min_routing_layer M2 -max_routing_layer M7 \
   -rc_congestion_ignored_layers {M1 M2 M8 M9}
```

To use more layers for RC estimation and congestion analysis than for routing, use the remove\_ignored\_layers command to remove the layer restriction for RC estimation and

congestion analysis. For example, to use layers M2 through M7 for routing and layers M2 through M8 for RC estimation and congestion analysis, use the following commands:

```
icc_shell> set_ignored_layers \
   -min_routing_layer M2 -max_routing_layer M7 \
icc_shell> remove_ignored_layers M8
```

To report the ignored layers, use the report\_ignored\_layers command.

# **Specifying Routing Layers for Specific Nets**

To specify the routing layers for specific nets, use the set\_net\_routing\_layer\_constraints command (or choose Route > Routing Setup > Set Net Layer Constraints in the GUI).

To specify the minimum and maximum routing layers for specific nets, use the -min\_layer\_name and -max\_layer\_name options, respectively. For example, to use layers M2 through M7 for routing net n1, use the following command:

```
icc_shell> set_net_routing_layer_constraints [get_nets n1] \
   -min_layer_name M2 -max_layer_name M7
```

To report the routing layer constraints for specific nets, use the report\_net\_routing\_layer\_constraints command.

```
icc_shell> report_net_routing_layer_constraints [get_nets *]
```

To output a Tcl script that contains the <code>set\_net\_routing\_layer\_constraints</code> commands that are used to define the routing layer constraints for the specified nets, use the <code>-output</code> option when you run the <code>report\_net\_routing\_layer\_constraints</code> command.

# **Setting Routing Types**

For debugging, you can set or change the routing types of wires, vias, or paths to indicate which classic router routing engine you want to route them with.

To specify a routing of any type, use the set\_route\_type command (or choose Route > Routing Setup > Set Route Type in the GUI).

• For signal nets, you can specify the following route types: detail\_route or user.

```
icc_shell> set_route_type -signal type objects
```

• For clock nets, you can specify the following route types: ring, strap, tie\_off, or user.

```
icc_shell> set_route_type -clock type objects
```

• For power and ground nets, you can specify the following route types: ring, strap, tie off, user, std cell pin conn, Or macro/IO pin conn.

```
icc_shell> set_route_type -pg type objects
```

To remove a routing type, use the remove\_route\_by\_type command (or choose Route > Delete Route in the GUI).

# **Setting Routing Options**

You can specify options that control how the classic router performs global routing, track assignment, and detail routing, as well as miscellaneous routing options.

- To set routing options, use the set\_route\_options command (or choose Route> Routing Setup > Set Route Options in the GUI). To reset the options to their default values, use set route options -default (or click Default in the GUI).
- To report the settings of all routing options, use the report\_route\_options command.
- To generate a Tcl script that contains the set\_route\_options commands that are used to define the current routing option settings, use the -output option when you run the report\_route\_options command.

#### Note:

You can set additional global route options by using the <code>set\_groute\_options</code> command. You can set additional detail route options by using the <code>set\_droute\_options</code> command. For more information about these commands, see the man pages.

Table 2-4 lists the routing options set by the set\_route\_options command.

Table 2-4 set\_route\_options Command Options

| Option                                                                          | Valid values                         | Description                                                                                   |  |
|---------------------------------------------------------------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------|--|
| Global routing options (Global Routing tab in the GUI)                          |                                      |                                                                                               |  |
| -groute_skew_control  ("Skew control" check box in the GUI)                     | true   false                         | Enables (true) or disables (false) skew control during global routing.  The default is false. |  |
| -groute_skew_weight ("Skew control Weight" box in the GUI)                      | int<br>(must be between 1<br>and 10) | Specifies the weight associated with skew control.  The default is 5.                         |  |
| -groute_timing_driven  ("Timing driven" check box in the GUI)                   | true   false                         | Enables (true) or disables (false) timing-driven global routing. The default is false.        |  |
| <pre>-groute_timing_driven_weight ("Timing driven Weight" box in the GUI)</pre> | int<br>(must be between 1<br>and 7)  | Specifies the weight associated with timing-driven global routing.  The default is 4.         |  |
| -groute_congestion_weight ("Congestion weight" box in the GUI)                  | int<br>(must be between 1<br>and 12) | Specifies the weight associated with congestion-driven global routing.  The default is 4.     |  |
| -groute_clock_routing ("Clock routing" radio buttons in the GUI)                | normal   comb  <br>balanced          | Specifies the global-routing clock topology.  The default is balanced.                        |  |
| -groute_incremental (Incremental check box in the GUI)                          | true   false                         | Enables (true) or disables (false) incremental global routing.  The default is false.         |  |

Table 2-4 set\_route\_options Command Options (Continued)

| Option                                                                                                 | Valid values                         | Description                                                                                                |  |  |
|--------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------|--|--|
| Track assignment options (Track Assign tab in the GUI)                                                 |                                      |                                                                                                            |  |  |
| -track_assign_timing_driven  ("Timing driven" check box in the GUI)                                    | true   false                         | Enables (true) or disables (false) timing-driven track assignment. The default is false.                   |  |  |
| <pre>-track_assign_timing_driven_ weight ("Timing driven" Weight box in the GUI)</pre>                 | int<br>(must be between 1<br>and 10) | Specifies the weight associated with timing-driven track assignment.  The default is 1.                    |  |  |
| Detail routing options (Detail Routing tab in the GUI)                                                 |                                      |                                                                                                            |  |  |
| -droute_connect_tie_off ("Connect tie off" check box in the GUI)                                       | true   false                         | Enables (true) or disables (false) connection of tie-off nets during detail routing.  The default is true. |  |  |
| -droute_connect_open_nets ("Connect open nets" check box in the GUI)                                   | true   false                         | Enables (true) or disables (false) connection of open nets during detail routing.  The default is true.    |  |  |
| -droute_reroute_user_wires ("Reroute user wires" check box in the GUI)                                 | true   false                         | Specifies whether the router can reroute user-created wires. The default is false.                         |  |  |
| -droute_CTS_nets<br>("Change CTS nets" radio buttons in<br>the GUI)                                    | normal  <br>minor_change_<br>only    | Specifies whether only minor changes can be made to clock nets.  The default is minor_change_only.         |  |  |
| -droute_single_row_column_via<br>_array<br>("Single row column via array" radio<br>buttons in the GUI) | center   optimize                    | Specifies how to handle via arrays that consist of a single row and single column.  The default is center. |  |  |

Table 2-4 set\_route\_options Command Options (Continued)

| Option                                                                                                   | Valid values                         | Description                                                                                                        |
|----------------------------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| -droute_stack_via_less_than_<br>min_area<br>("Stack via less than min area" radio<br>buttons in the GUI) | forbid  <br>add_metal_stub           | Specifies how to handle stacked via arrays that do not meet the minimum area rule.  The default is add_metal_stub. |
| -droute_stack_via_less_than_<br>min_area_cost<br>("Stack via less than min area Cost"<br>box in the GUI) | int<br>(must be between 1<br>and 10) | Controls the cost associated with adding metal stubs. The default is 0.                                            |

#### Miscellaneous options (Miscellaneous tab in the GUI)

| -poly_pin_access ("Poly pin access" radio buttons in the GUI          | auto   off                                                             | Controls poly pin access is handled.  The default is auto.                             |
|-----------------------------------------------------------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| -drc_distance ("DRC distance" radio buttons in the GUI)               | diagonal  <br>manhattan                                                | Specifies how to measure distances for design rule checking.  The default is diagonal. |
| -same_net_notch ("Same net notch" radio buttons in the GUI)           | ignore  <br>check_and_fix                                              | Specifies whether to check the same net notch rule.  The default is ignore.            |
| -fat_wire_check ("Fat wire checking" radio buttons in the GUI)        | <pre>quick   merge_then_check</pre>                                    | Controls how the fat wire check is handled.  The default is merge_then_check.          |
| -merge_fat_wire_on ("Merge fat wire during" radio buttons in the GUI) | <pre>preroute_only   preroute_signal   preroute_signal_ blockage</pre> | Controls when fat wires are merged.  The default is preroute_signal.                   |

Table 2-4 set\_route\_options Command Options (Continued)

| Option                                                                            | Valid values              | Description                                                           |
|-----------------------------------------------------------------------------------|---------------------------|-----------------------------------------------------------------------|
| -fat_blockage_as  ("Treat fat blockages as" radio buttons in the GUI)             | thin_wire  <br>fat_wire   | Specifies how to treat fat blockages.  The default is fat_wire.       |
| -wire_contact_eol_rule ("Wire/Contact end of line rule" radio buttons in the GUI) | ignore  <br>check_and_fix | Specifies whether check the end-of-line rule.  The default is ignore. |

# **Setting Signal Integrity Options**

To improve signal integrity, you can enable crosstalk prevention during global routing and track assignment and enable crosstalk fixing during postroute optimization. To perform these signal integrity tasks when you run the route\_opt command, you must use the -xtalk\_reduction option.

For more information about the IC Compiler signal integrity features, see Chapter 8, "Signal Integrity," in the IC Compiler Implementation User Guide.

# **Enabling Crosstalk Prevention**

By default, the classic router does not perform crosstalk reduction. If you enable signal integrity mode, the classic router performs crosstalk reduction during global routing and track assignment. To enable signal integrity mode, enter the following command:

```
icc_shell> set_si_options -route_xtalk_prevention true
```

The default crosstalk prevention threshold is 0.35 volts, which is probably too relaxed. If your design has crosstalk violations, use the set si options

-route\_xtalk\_prevention\_threshold command to lower the crosstalk prevention threshold during track assignment to a value between in the range of 0.25 to 0.35 volts. When you set the crosstalk prevention threshold, the tool automatically sets the threshold noise ratio common route option.

When you enable crosstalk prevention, the classic router avoids putting long, parallel wires on adjacent tracks during track assignment. To minimize noise, track assignment estimates the potential noise with a simplified crosstalk checker and reassigns wires to reduce the potential noise using the noise threshold.

#### **Enabling Crosstalk Fixing**

To minimize crosstalk-induced noise, you can specify the aggressors for a victim net. Crosstalk prevention during postroute optimization uses that information to minimize the crosstalk-induced noise from the aggressor nets.

To specify aggressors for a victim net, use the set\_net\_aggressors command (or choose Route > Routing Setup > Set Net Aggressors in the GUI). To specify the victim net, use the -victim\_net option (or the "Victim net" box in the GUI). To specify the aggressor nets, use the -aggressor\_nets option (or the "Aggressor nets" box in the GUI).

# **Enabling Distributed Routing**

You can use distributed routing to decrease the runtime for the following routing commands:

- route\_opt
- route\_group
- route\_auto
- route\_detail
- route\_search\_repair
- optimize\_wire\_via
- route\_eco
- verify\_route
- route spreadwires
- insert\_redundant\_vias
- fix\_lcc\_hotspot

#### Note:

You can also use distributed routing for the following power and ground routing commands: create\_power\_straps and preroute\_standard\_cells. These commands are described in the *IC Compiler Design Planning User Guide*.

#### To perform distributed routing, you must

#### 1. Have the appropriate licenses

To perform distributed routing using three or four CPUs, you must have the Galaxy-MultiRoute4 license. To perform distributed routing using more than four CPUs, you must have the Galaxy-MultiRoute8 license.

#### 2. Set up the network

To set up the network for distributed routing, run the set\_distributed\_route command (or choose File > Distributed Route Jobs > Set Distributed Route in the GUI). For more information about setting up the network, see the following section, "Setting Up the Distributed Routing Network."

#### 3. Select the partitioning method

Distributed routing divides the design into several routing partitions, based on size and congestion. These partitions are then routed on separate CPUs, in parallel, greatly reducing the overall runtime. One CPU is used to reassemble the partitions. For example, with four CPUs available, a typical runtime improvement would be a 3.5x reduction in overall routing time.

By default, the classic router uses a two-pass partitioning method. If your design is very large, you might be able to reduce runtime by using the one-pass method instead. To use the one-pass method, set the droute\_enable\_one\_pass\_partitioning variable to 1.

#### 4. Invoke distributed routing

To enable distributed routing for all routing commands that support distributed routing, set the <code>droute\_numCPUs</code> variable to a number greater than one before running the routing commands.

To invoke distributed routing for a specific routing command, use the <code>-num\_cpu</code> option to specify multiple CPUs when you run the routing command.

#### Note:

If you specify both the <code>droute\_numCPUs</code> variable and the <code>-num\_cpu</code> command option, the value specified by the <code>-num\_cpu</code> option overrides the value specified by the <code>droute\_numCPUs</code> variable. In addition, the number of CPUs specified must be less than or equal to the number of CPUs defined by the <code>set\_distributed\_route</code> command.

# **Setting Up the Distributed Routing Network**

The classic router supports distributed routing operations either by using a package called *jp* to set up the communication between jobs on a network or by using resources under the control of the Load Sharing Facility (LSF) network. The following sections describe how to set up the network for distributed routing using each of these methods.

#### Setting Up Distributed Routing With jp

To set up distributed routing with the jp package,

1. If you are using processors on other machines, create a .rhosts file in your home directory.

The .rhosts file specifies the remote machines that you can access by listing one entry per line. You might need to specify the complete host name, including the domain name.

To determine the host name to put in the .rhosts file,

- a. Log in the machine you want to use by using the rlogin shell command.
- b. Determine the host name by using the finger -1 shell command.

To be safe, you can include both the simple and the complete host name for each remote machine, as shown in the following example .rhosts file.

```
machineName1
machineName1.domain.company.com
machineName2
machineName2.domain.company.com
```

- 2. Open the Milkyway design library, as described in Chapter 3, "Preparing the Design" in the *IC Compiler Implementation User Guide*.
- 3. Run the set\_distributed\_route command to specify the following:
  - o The machines to use (-jp\_machines option)

You can specify up to 16 machines, including the current machine.

If you are using only the current machine, you do not need to specify this option, because this is the default.

For example, to use *machineName1*, *machineName2*, and *machineName3* in addition to the current machine, enter

```
icc_shell> set_distributed_route \
    -jp_machines {machineName1 machineName2 machineName3}
```

The maximum number of CPUs to use on each machine (-jp\_limit option)

For each machine for which you want to limit the number of CPUs used, specify the machine name and the maximum number of CPUs. The machine name must match a machine specified in the <code>-jp\_machines</code> option. If you do not specify a limit for a machine, distributed routing will use all CPUs on that machine.

For example, to use a maximum of two CPUs on each machine, enter

```
icc_shell> set_distributed_route \
    -jp_limit {machineName1 2 machineName2 2 machineName3
2}
```

The location of the executable file for each machine (-jp\_bin option)

By default, distributed routing uses the location of the current icc\_shell executable. If the executable file for a remote machine is in a location other than the default location, you must specify the machine name and the executable location for that machine. The machine name must match a machine specified in the <code>-jp\_machines</code> option.

For example, to specify the executable for *machineName1*, enter

```
icc_shell> set_distributed_route \
   -jp_bin {machineName1 / machineName1/$SYNOPSYS/bin/}
```

where \$SYNOPSYS is the path to the installation directory.

The location of the Milkyway design library (-jp\_lib option)

By default, distributed routing uses the location of the current Milkyway design library. If the design library for a remote machine is in a location other than the default location, you must specify the machine name and the design library location for that machine. The machine name must match a machine specified in the <code>-jp\_machines</code> option.

#### Note:

When using the jp package, you can disconnect the network used for distributed routing by using the set\_distributed\_route -jp\_disconnect option. This command disconnects all previously defined remote machines. You can also use the close\_distributed\_route command to close all of the sockets and shut down the daemons.

#### **Setting Up Distributed Routing With LSF**

To set up distributed routing with LSF, run the set\_distributed\_route command to

- Select LSF as the distributed routing method (-1sf option)
- Specify the LSF bsub command options to use when submitting jobs (-1sf\_advanced option)

By default, distributed routing with LSF does not use any bsub options. For more control over the job submissions, you can specify the bsub options to use. Common bsub options include -q (the queue to which to submit the jobs), -m (the machines to which to submit the jobs), and -M (the minimum memory required). For more information about the bsub command options, see the LSF documentation.

# **Reporting Distributed Route Jobs**

To get information about a specific distributed route job, use the report\_distributed\_route command. You must use the -job option to identify the job to report. To get the job identification number, use a system command such as the UNIX top or ps command.

# **Cancelling Distributed Route Jobs**

To cancel an active distributed route job, use the <code>remove\_distributed\_route</code> command. You must use the <code>-job</code> option to identify the job to cancel. To get the job identification number, use a system command such as the UNIX <code>top</code> or <code>ps</code> command.

# 3

# Routing Clock and Signal Nets

This chapter describes how to use the classic router to perform routing tasks. It contains the following sections:

- Routing Critical Nets
- Routing Signal Nets
- Shielding Nets
- Performing ECO Routing
- Reporting Cell Placement and Routing Statistics
- Verifying the Routed Design

# **Routing Critical Nets**

You can preroute a group of nets, such as clock nets, before routing the rest of the nets in the design. Taking this step can help you find timing problems. For example, you can route clock and bus pins to prerouted clock and bus wires and then perform timing analysis on these nets. If the timing results are satisfactory, you can route the remaining nets.

To preroute a group of nets, use the <code>route\_group</code> command (or choose Route > Net Group Route in the GUI). To route all clock nets, use the <code>-all\_clock\_nets</code> option (or select the "All clock nets" radio button in the GUI); otherwise, you can specify a collection of nets to route by using the <code>-nets</code> option (or the "Specified nets" box in the GUI).

For example, to route all clock nets, enter

icc\_shell> route\_group -all\_clock\_nets

Table 3-1 lists the options for the route\_group command.

Table 3-1 route\_group Command Options

| Option                                              | Description                                                                            |
|-----------------------------------------------------|----------------------------------------------------------------------------------------|
| -no_global                                          | Skips the global routing phase.                                                        |
| ("Global route" check box in the GUI)               | By default, route_group performs global routing, track assignment, and detail routing. |
| -no_track                                           | Skips the track assignment phase.                                                      |
| ("Track assignment" check box in the GUI)           | By default, route_group performs global routing, track assignment, and detail routing. |
| -no_detail                                          | Skips the detail routing phase.                                                        |
| ("Detail route" check box in the GUI)               | By default, route_group performs global routing, track assignment, and detail routing. |
| -nets collection_of_nets                            | Specifies the nets to route.                                                           |
| ("Specified nets" radio button and text box in GUI) | Either this option or the <code>-all_clock_nets</code> option is required.             |
| -all_clock_nets                                     | Routes all clock nets.                                                                 |
| ("All clock nets" radio button in the GUI)          | Either this option or the -nets option is required.                                    |

Table 3-1 route\_group Command Options (Continued)

| Option                                                                                                                                                 | Description                                                                                                                                                                                                                                                                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -dont_optimize_route_pattern ("Optimize routing pattern" check box in the GUI)                                                                         | Disables optimization of the routing pattern. By default, the routing pattern is optimized.                                                                                                                                                                                                                                                        |
| -utilize_dangling_wires<br>("Utilize dangling wires" check box in<br>the GUI)                                                                          | Enables reuse of existing dangling routes to fix open nets.  By default, the router does not reuse existing dangling routes.                                                                                                                                                                                                                       |
| -trim_antenna_of_user_wires  ("Trim wire segments of prerouted wires" check box in the GUI)  -num_cpus int  ("Clock routing" radio buttons in the GUI) | Enables trimming for wire segments of prerouted wires.  By default, the router does not trim wire segments of prerouted wires.  Specifies the number of CPUs to use for distributed routing. You must specify a value between 1 and 63. For information about setting up for distributed routing, see "Enabling Distributed Routing" on page 2-18. |
|                                                                                                                                                        | The default is 1.                                                                                                                                                                                                                                                                                                                                  |

# **Shielding Clock Nets**

The classic router uses nondefault routing rules to define the shielding width and spacing. For information about nondefault routing rules, see "Using Nondefault Routing Rules" on page 2-7.

#### Note:

If you do not define the shielding spacing for clock nets, the classic router adds default spacing as shield spacing on clock nets.

After defining the nondefault routing rules and routing the clock nets, shield the clock nets by using the create\_auto\_shield command (or choosing Route > Create Auto Shield in the GUI). For information about shielding nets, see "Shielding Nets" on page 3-32.

# **Routing Signal Nets**

Before you route the signal nets, all clock nets must be routed without violations.

You can route the signal nets by using one of the following methods:

• Use the route opt core command

The route\_opt command performs global routing, track assignment, detail routing, search and repair, and postroute optimization.

Use automatic routing (the route\_auto basic command)

The route\_auto basic command performs global routing, track assignment, and detail routing.

When you run route\_auto, the classic router reads the design database before starting routing and updates the database when all routing steps are done. If you stop automatic routing before it performs detail routing, the classic router checks the input data when you restart routing with this command.

Use the basic commands to perform the standalone routing tasks

To perform global routing, use the <code>route\_global</code> command. To perform track assignment, use the <code>route\_track</code> command. To perform detail routing, use the <code>route\_detail</code> command. To perform search and repair, use the <code>route\_search\_repair</code> command.

When you run a standalone routing command, such as route\_global or route\_detail, the classic router reads in the design database at the beginning of each routing command and updates the database at the end of each command. The router does not check the input data. For example, if the track assignment step is skipped and you run detail routing directly, the classic router might generate bad routing results.

If you need to customize your routing flow or you need to run a large design step-by-step, you might want to use the standalone routing commands instead of the <code>route\_opt</code> command or automatic routing.

# Routing Signal Nets by Using the route\_opt Command

Before you use the <code>route\_opt</code> command to route the signal nets, you must define the routing options, as described in "Setting Routing Options" on page 2-13 and set the <code>route\_opt</code> routing and optimization strategy, as described in the following section. If logical DRC violations remain after running the <code>route\_opt</code> command, you can use focal optimization to address these remaining violations, as described in "Performing Focal Optimization" on page 3-17.

# **Setting the Routing and Optimization Strategy**

The IC Compiler tool provides strategy controls that you set to guide how routing and postroute optimizations are run.

To set the routing and optimization strategy, use the  $set\_route\_opt\_strategy$  command (or choose Route > Set Core Routing and Optimization Strategy in the GUI).

Table 3-2 describes the set\_route\_opt\_strategy command options. For more information, see the man page.

Table 3-2 set\_route\_opt\_strategy Command Options

| Command option                                                                               | Valid values                          | Description                                                                                                            |
|----------------------------------------------------------------------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| -fix_hold_mode  ("Fix hold optimization stage" radio                                         | all   route_base                      | The stages for which hold optimization is performed.                                                                   |
| buttons in the GUI)                                                                          |                                       | You can select prerouting, global routing, and detail routing (all) or global routing and detail routing (route_base). |
|                                                                                              |                                       | The default is route_base.                                                                                             |
| -power_aware_optimization ("Power aware optimization flow" check box in the GUI)             | true   false                          | Controls whether postroute optimizations for setup, hold, and design rule constraints are power-aware.                 |
|                                                                                              |                                       | The default is false.                                                                                                  |
| -xtalk_reduction_loops ("Maximum crosstalk reduction                                         | int<br>(must be between -1            | The maximum number of crosstalk reduction optimization cycles.                                                         |
| cycles" box in the GUI)                                                                      | and 10)                               | The default is 2.                                                                                                      |
| -search_repair_loops<br>("Maximum initial route Search and<br>Repair cycles" box in the GUI) | int<br>(must be between 0<br>and 500) | The maximum number of initial routing search and repair iterations.  The classic router default is 15.                 |
| -eco_route_search_repair_loops ("Maximum ECO Search and Repair cycles" box in the GUI)       | int<br>(must be between 0<br>and 500) | The maximum number of ECO search and repair iterations. The classic router default is 5.                               |

Table 3-2 set\_route\_opt\_strategy Command Options (Continued)

| Command option                                                                                | Valid values | Description                                                                                                                                                         |
|-----------------------------------------------------------------------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -route_drc_threshold  ("Route violations threshold to trigger the reduction Search and Repair | int          | The threshold number of routing violations before limiting search-and-repair to one iteration.                                                                      |
| loop" box in the GUI)                                                                         |              | The default is 3000.                                                                                                                                                |
| <pre>-enable_port_punching true   false</pre>                                                 | true false   | Controls whether postroute optimizations can modify the logical topology of a net to increase the area available for buffer insertion to fix constraint violations. |
|                                                                                               |              | The default is false.                                                                                                                                               |

To report your settings, use the report\_route\_opt\_strategy command.

# **Enabling Fixing of Hold Time Violations**

The route\_opt command fixes hold time violations on those clocks that have a fix\_hold attribute of true.

To disable hold fixing, enter the following command to remove the fix\_hold attribute from all clocks:

```
icc_shell> remove_attribute [get_clocks *] fix_hold
```

To enable hold fixing, use the  $set_fix_hold$  command to set the  $fix_hold$  attribute on the clocks on which to perform hold fixing.

For example, to enable hold fixing on clock clk, enter the following command:

```
icc_shell> set_fix_hold clk
```

To enable hold fixing on all clocks, enter the following command:

```
icc_shell> set_fix_hold [all_clocks]
```

#### Note:

If you enable hold fixing for a multicorner-multimode design, the tool considers the timing from driver to endpoint on a per-scenario basis and fixes hold violations accordingly.

You can specify a list of preferred buffers for hold fixing during postroute optimization by using the set\_prefer and set\_fix\_hold\_options commands. For example, the following commands instruct the tool to use cells BUF1 and BUF2 as the preferred cells during hold

fixing. Note that cells BUF1 and BUF2 can also be used to resolve setup and DRC violations.

```
icc_shell> set_prefer -min {BUF1 BUF2}
icc_shell> set_fix_hold_options -preferred_buffer
```

If you use the <code>set\_dont\_use</code> command to set the <code>dont\_use</code> attribute on cells BUF1 and BUF2 as shown in the following script, the tool uses cells BUF1 and BUF2 to fix hold violations, but not setup and DRC violations.

```
icc_shell> set_dont_use {BUF1 BUF2}
icc_shell> set_prefer -min {BUF1 BUF2}
icc shell> set fix hold options -preferred buffer
```

The IC Compiler tool also provides the following variables that control hold fixing:

• routeopt\_allow\_min\_buffer\_with\_size\_only

By default, the tool cannot insert buffers during size-only optimization. When you set this variable to true and use the <code>-size\_only</code> option when you run the <code>route\_opt</code> command, the tool can insert buffers to fix hold violations.

• routeopt\_enable\_aggressive\_optimization

This variable enables additional, aggressive fixing of hold violations.

psyn\_onroute\_disable\_hold\_fix

This variable disables hold fixing, but preserves the minimum timing on clocks that have the fix hold attribute.

# **Setting the Crosstalk Reduction Options**

By default, the route\_opt command does not perform crosstalk reduction. To perform crosstalk reduction,

- 1. Enable signal integrity mode by setting the set\_si\_options -delta\_delay option to true.
  - When you enable signal integrity mode, the route\_opt command also performs signal-integrity-aware postroute optimization.
- 2. (Optional) Enable static noise fixing by setting the set\_si\_options -static\_noise option to true.
  - When you enable static noise fixing, the route\_opt command also fixes static noise violations during postroute optimization.
- 3. Run the route\_opt command with the -xtalk\_reduction or -only\_xtalk\_reduction option.
  - To perform both crosstalk reduction and postroute optimization, use the -xtalk\_reduction option. To perform only crosstalk reduction and not postroute optimization, use the -only\_xtalk\_reduction option.

By default, when signal integrity mode is enabled and you run the <code>route\_opt</code> command with the <code>-xtalk\_reduction</code> or <code>-only\_xtalk\_reduction</code> option, the classic router performs a single iteration of crosstalk reduction on all nets with setup violations and, if enabled, static noise violations. You can increase the number of iterations by setting the <code>-xtalk\_reduction\_loops</code> option of the <code>set\_route\_opt\_strategy</code> command. You can restrict the nets selected for crosstalk reduction by setting the <code>routeopt\_xtalk\_reduction</code> setup threshold variable.

The default method for reducing crosstalk is to increase the spacing between nets. To further reduce crosstalk and improve timing QoR, the tool can perform cell sizing by using footprint swapping on cells on the victim or aggressor nets in addition to increasing the spacing between nets. To enable cell sizing during crosstalk reduction, set the routeopt\_xtalk\_reduction\_cell\_sizing variable to true before running the route\_opt command.

# **Using Scenario Compression for Multicorner-Multimode Designs**

For multicorner-multimode designs that have fewer modes than scenarios, you can improve the capacity and runtime of postroute optimization without sacrificing QoR by enabling scenario compression. When you enable scenario compression, the original set of scenarios is compressed into a subset of dominant scenarios. In addition, the constraints of this dominant subset are modified to capture any violations from the nondominant scenarios. To identify the dominant scenarios used during compression, the tool appends a suffix of \_\_z\_ to the scenario names.

To use scenario compression,

1. If your design is not yet routed, perform initial routing by running the route\_opt -initial route only command.

```
icc_shell> route_opt -initial_route_only
```

2. Enable scenario compression by running the compress scenarios command.

```
icc_shell> compress_scenarios
```

By default, the tool determines the number of dominant scenarios. To specify a maximum number of dominant scenarios, use the <code>-max\_compression</code> option with the <code>compress scenarios</code> command.

3. Run the route\_opt command one or more times to perform initial or incremental postroute optimization.

#### Note:

For the best runtime benefits, run the route opt command at least two times.

To run initial postroute optimization, use the <code>route\_opt -skip\_initial\_route</code> command. To run incremental postroute optimization, use the <code>route\_opt -incremental</code> command. You can use other <code>route\_opt</code> options as necessary to configure the postroute optimization.

4. Disable scenario compression by running the uncompress\_scenarios command.

```
icc shell> uncompress scenarios
```

#### Note:

Scenario compression is supported only by the route\_opt command with the -skip\_initial\_route or -incremental option. You must revert your scenarios back to the uncompressed state before running any other commands, including timing analysis commands.

# Running the route\_opt Command

To run routing and postroute optimization, use the route\_opt command (or choose Route > Core Routing and Optimization in the GUI).

By default, the route\_opt command performs the following tasks:

#### Global routing

By default, global routing is not timing-driven and does not do crosstalk prevention.

To enable timing-driven global routing, use the set\_route\_options
-groute\_timing\_driven true command (or choose Route > Routing Setup > Set
Route Options in the GUI and select "Timing driven" in the Global Routing tab).

To enable crosstalk-prevention mode, set the signal integrity options as described in "Setting Signal Integrity Options" on page 2-17, and use the -xtalk\_reduction or -only xtalk reduction option when you run the route opt command.

#### Track assignment

By default, track assignment is not timing-driven and does not do crosstalk prevention.

To enable timing-driven track assignment, use the set\_route\_options
-track\_assign\_timing\_driven true command (or choose Route > Routing Setup >
Set Route Options in the GUI and select "Timing driven" in the Track Assign tab).

To enable crosstalk-prevention mode, set the signal integrity options as described in "Setting Signal Integrity Options" on page 2-17, and use the -xtalk\_reduction or -only\_xtalk\_reduction option when you run the route\_opt command.

#### Detail routing

To enable crosstalk-reduction mode, set the signal integrity options as described in "Setting Signal Integrity Options" on page 2-17, and use the -xtalk\_reduction or -only xtalk reduction option when you run the route opt command.

- · Search and repair
- Postroute optimization

By default, the IC Compiler tool uses medium effort during postroute optimization. You can change the effort level by using the <code>-effort</code> option. When you select high effort, the tool is more aggressive during optimization and runs three optimization loops.

In addition to controlling the optimization effort, the effort setting also controls the type of sizing performed when you use the <code>-size\_only</code> option.

- During low effort optimization, the tool performs footprint swapping.
- During medium effort optimization, the tool performs in-place size-only optimization.
- o During high effort optimization, the tool performs cell sizing.

You can also use variables to control the effort used for specific optimizations.

- o To enable additional, aggressive fixing of hold time and maximum transition violations, set the routeopt enable aggressive optimization variable to true.
- o To restrict total negative slack optimization to size-only optimization, set the routeopt\_restrict\_tns\_to\_size\_only variable to true.

For designs that contain block abstraction models, the tool performs top-level interface optimization during postroute optimization. For information about top-level interface optimization, see Chapter 10, "Using Hierarchical Models," in the *IC Compiler Implementation User Guide*.

In addition to performing timing optimization, you can perform the following postroute optimizations: leakage power, signal integrity, wire length and via count reduction, and area recovery.

- o To perform leakage-power optimization,
  - 1. For a multicorner-multimode design, use the set\_scenario\_options command to select the leakage scenarios.
    - For more information about selecting the leakage scenarios, see Chapter 3, "Preparing the Design," in the *IC Compiler Implementation User Guide*.
  - 2. (Optional) Enable power-aware postroute optimization by setting the -power\_aware\_optimization option of the set\_route\_opt\_strategy command to true.
    - By default, when power-aware postroute optimization is enabled, leakage power has a lower cost priority than setup, hold, and design rule constraints. You can change these cost priorities by setting the following variables to true: routeopt\_leakage\_over\_setup, routeopt\_leakage\_over\_hold, and routeopt\_leakage\_over\_drc.
  - 3. Enable leakage-power optimization and recovery by using the -power option when you run the route\_opt command.

To perform only power recovery during incremental postroute optimization, use the -only\_power\_recovery option with the route\_opt -incremental command.

- To perform signal integrity optimization,
  - 1. Set the crosstalk reduction options as described in "Setting the Crosstalk Reduction Options" on page 3-8.
  - 2. Use the -xtalk\_reduction option when you run the route\_opt command.

- o To perform wire length and via count reduction optimization, use the -optimize wire via option when you run the route opt command.
- o To perform area recovery, use the -area\_recovery option when you run the route opt command.

To perform only area recovery during incremental postroute optimization, use the -only\_area\_recovery option with the route\_opt command.

By default, the postroute optimization step generates QoR reports before and after the postroute optimization. If you do not need the QoR reports that are generated after postroute optimization, you can reduce runtime by setting the routeopt\_skip\_report\_qor variable to true. Setting this variable to true prevents generation of QoR reports after postroute optimization; this variable does not affect the generation of QoR reports before postroute optimization. To get more information about the optimization process, you can enable verbose reporting during the hold fixing, DRC fixing, and crosstalk reduction stages by setting the routeopt\_verbose variable. This variable uses bitwise operation to enable various reporting capabilities. For details about setting this variable, see SolvNet article 032174.

If you want to analyze the routing results before performing postroute optimization or you want to use scenario compression during postroute optimization, first run the <code>route\_opt</code> command without postroute optimization (<code>-initial\_route\_only</code> option), and then run the <code>route\_opt</code> command with only postroute optimization. The <code>route\_opt</code> command provides two options that perform only postroute optimization:

-skip initial route

This option performs two passes of postroute optimization and ECO routing. If signal integrity mode is enabled, the first pass does not perform crosstalk reduction or signal integrity optimization, but the second pass does.

• -incremental

This option performs one pass of postroute optimization and ECO routing. If signal integrity mode is enabled, the tool performs crosstalk reduction and signal integrity optimization.

When you use the -incremental option, you can restrict postroute optimization to one of the following optimization techniques:

Register-to-register optimization

To restrict postroute optimization to use only register-to-register optimization, use the <code>-register\_to\_register</code> option with the <code>-incremental</code> option. By default, register-to-register optimization fixes setup, hold, and logical DRC violations. To restrict the optimization to a specific violation type, use the <code>-size\_only</code>, <code>-only\_hold\_time</code>, or <code>-only\_design\_rule</code> option in addition to the <code>-incremental</code> and <code>-register\_to\_register</code> options.

#### Sizing of weak drive cells

To restrict postroute optimization to use only footprint-preservation sizing to increase the drive strength of weak cells, set the <code>routeopt\_only\_size\_weak\_drive\_cells</code> variable to <code>true</code> before running the <code>route\_opt\_-incremental</code> command.

You can use this technique to generate a robust design with similar or better QoR that is less sensitive to variations.

To analyze the routing results before performing postroute optimization, use the following flow:

```
icc_shell> route_opt -initial_route_only
# analyze routing results
icc_shell> route_opt -skip_initial_route
```

To use scenario compression during postroute optimization, use the following flow:

```
icc_shell> route_opt -initial_route_only
icc_shell> compress_scenarios
icc_shell> route_opt -skip_initial_route
icc_shell> route_opt -incremental
icc_shell> uncompress_scenarios
```

For more information about using scenario compression, see "Using Scenario Compression for Multicorner-Multimode Designs" on page 3-8.

Table 3-3 describes the route\_opt command options.

Table 3-3 route\_opt Command Options

| Command option                                          | Description                                                                                                                               |
|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| -effort low   medium   high (Effort options in the GUI) | Specifies the optimization effort level. Higher effort levels provide more aggressive optimization at a runtime cost.                     |
|                                                         | The default is medium.                                                                                                                    |
| -stage global  track   detail                           | Specifies the last routing stage performed by the                                                                                         |
| ("Run optimization after" options in the                | route_opt command before performing optimization.                                                                                         |
| GUI)                                                    | If you specify global or detail, only the specified stage is run. If you specify track, both global routing and track assignment are run. |
|                                                         | By default, the route_opt command performs optimization after running global routing, track assignment, and detail routing.               |

Table 3-3 route\_opt Command Options (Continued)

| Command option                                                                        | Description                                                                                                                                                                                        |
|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -xtalk_reduction ("Crosstalk reduction and SI                                         | Performs crosstalk reduction and signal integrity optimization.                                                                                                                                    |
| optimization" option in the GUI)                                                      | By default, the route_opt command does not perform crosstalk reduction or signal integrity optimization.                                                                                           |
| -only_xtalk_reduction ("Crosstalk reduction optimization only"                        | Performs only crosstalk reduction (not signal integrity optimization).                                                                                                                             |
| option in the GUI)                                                                    | By default, the route_opt command does not perform crosstalk reduction or signal integrity optimization.                                                                                           |
| -power                                                                                | Performs leakage-power optimization and recovery.                                                                                                                                                  |
| ("Perform power optimization" check box in the GUI)                                   | When you use this option to perform leakage-power optimization, the tool uses low-effort leakage cell selection.                                                                                   |
|                                                                                       | By default, the route_opt command does not perform leakage-power optimization.                                                                                                                     |
| -skip_initial_route ("Skip initial routing" check box in the GUI)                     | Performs postroute optimization without routing.                                                                                                                                                   |
| -initial_route_only                                                                   | Performs only initial routing without postroute optimization.                                                                                                                                      |
| ("Initial routing only" check box in the GUI)                                         | This option works in conjunction with the -stage option.                                                                                                                                           |
| -size_only                                                                            | Resolves setup time violations by sizing only.                                                                                                                                                     |
| ("Sizing only optimization" check box in the GUI)                                     | To use register-to-register optimization to resolve only setup time violations during incremental postroute optimization, use this option with the -incremental and -register_to_register options. |
| -optimize_wire_via                                                                    | Performs wire and via optimization.                                                                                                                                                                |
| ("Optimize wire and via routing" check box in the GUI)                                | By default, the route_opt command does not perform wire and via optimization.                                                                                                                      |
| -area_recovery                                                                        | Recovers area for cells not on critical paths.                                                                                                                                                     |
| ("Recover area for cells that are not on critical timing paths" check box in the GUI) |                                                                                                                                                                                                    |

Table 3-3 route\_opt Command Options (Continued)

| Command option                                                                              | Description                                                                                                                                                                                                                                                                                                       |
|---------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -wire_size ("Use wire sizing to fix setup time violations" check box in the GUI)            | Determines whether wire sizing is used to fix setup time violations.                                                                                                                                                                                                                                              |
| -incremental ("Incremental mode" check box in the GUI)                                      | Performs incremental postroute optimization.                                                                                                                                                                                                                                                                      |
| <pre>-incremental -register_to_register ("Register to register" check box in the GUI)</pre> | Performs only register-to-register optimization to resolve setup, hold, and logical DRC violations during incremental postroute optimization. You can restrict the optimization to a specific violation type by also using the <code>-size_only,-only_hold_time</code> , <code>Or-only_design_rule</code> option. |
| -incremental -only_wire_size ("Timing optimization only with wire size" option in the GUI)  | Performs only wire sizing to resolve setup time violations during incremental postroute optimization.                                                                                                                                                                                                             |
| <pre>-incremental -only_hold_time ("Hold timing optimization only" option in the GUI)</pre> | Resolves only hold time violations during incremental postroute optimization. Use the <pre>set_fix_hold command</pre> to enable hold time fixing.  To use only register-to-register optimization to resolve hold                                                                                                  |
|                                                                                             | time violations during incremental postroute optimization, use this option with the -register_to_register option.                                                                                                                                                                                                 |
| -incremental -only_area_recovery ("Area recovery only" option in the GUI)                   | Performs only area recovery during incremental postroute optimization.                                                                                                                                                                                                                                            |
| -incremental -only_design_rule ("Fix design rules only" option in the                       | Performs only logical design rule fixing during incremental postroute optimization.                                                                                                                                                                                                                               |
| GUI)                                                                                        | By default, timing has a higher cost priority than design rule constraints. When you use this option, you can give a higher cost priority to design rule constraints by setting the routeopt_drc_over_timing variable to true.                                                                                    |
|                                                                                             | To use only register-to-register optimization to resolve logical design rule violations during incremental postroute optimization, use this option with the -register_to_register option.                                                                                                                         |

Table 3-3 route\_opt Command Options (Continued)

| Command option                                      | Description                                                                                                                                                                                                                                                                 |
|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -incremental -only_power_recovery                   | Performs only power recovery during incremental postroute optimization.                                                                                                                                                                                                     |
| ("Power recovery only" option in the GUI)           | When you use this option, the -effort option controls the cell-selection effort level for leakage-power optimization.                                                                                                                                                       |
|                                                     | By default, leakage power has a lower cost priority than setup, hold, and design rule constraints. You can change these cost priorities by setting the following variables to true: routeopt_leakage_over_setup, routeopt_leakage_over_hold, and routeopt_leakage_over_drc. |
| -num_cpus number  ("Number of CPUs" box in the GUI) | Specifies the number of CPUs to use for distributed routing. You must specify a value between 1 and 63. For information about setting up for distributed routing, see "Enabling Distributed Routing" on page 2-18.  The default is 1.                                       |

### **Saving Intermediate Results**

To save intermediate <code>route\_opt</code> results, enable checkpointing by setting the <code>routeopt\_checkpoint</code> variable to <code>true</code>. When checkpointing is enabled, the <code>route\_opt</code> command saves the design after each major stage. Table 3-4 shows the designs saved by <code>route\_opt</code> checkpointing.

Table 3-4 Designs Saved By route\_opt Checkpointing

| Design name         | Saved after                      |
|---------------------|----------------------------------|
| design_name_RT      | Initial routing                  |
| design_name_ORPRT   | Wire and via optimization        |
| design_name_OR_n    | Each postroute optimization pass |
| design_name_ECORT_n | Each ECO routing pass            |
| design_name_RCRED   | Crosstalk reduction              |
| design_name_POR     | Power optimization               |
| design_name_PECORT  | Power optimization ECO routing   |

 Design name
 Saved after

 design\_name\_HOLD\_PRE
 Preroute-based hold optimization

 design\_name\_HOLD
 Global-route-based hold optimization

 design\_name\_INCOR
 Optimization after incremental route\_opt

 design\_name\_HOLD
 ECO routing after incremental route\_opt

Table 3-4 Designs Saved By route\_opt Checkpointing (Continued)

# **Performing Focal Optimization**

You can use the <code>focal\_opt</code> command to perform aggressive, topology-based optimization on your postroute design that is focused on fixing either the setup, hold, or logical DRC violations that remain after the postroute optimization performed by the <code>route\_opt</code> command. You can also use the <code>focal\_opt</code> command to perform register-to-register optimization, crosstalk reduction, or final stage leakage recovery.

For each run, you must specify the focus of the optimization.

- To fix setup violations, use the -setup\_endpoints option.
  - To fix all setup violations, set this option to all. To fix specific setup violations, specify the endpoints by using an endpoint file or by providing a collection that contains the endpoints. For information about the format of the endpoint file, see "Endpoint File Format" on page 3-19.
- To fix hold violations, use the -hold endpoints option.
  - To fix all hold violations, set this option to all. To fix specific hold violations, specify the endpoints by using an endpoint file or by providing a collection that contains the endpoints. For information about the format of the endpoint file, see "Endpoint File Format" on page 3-19.
- To fix logical DRC violations on nets, use the -drc\_nets option.
  - To fix DRC violations on all nets, set this option to all. To fix DRC violations on specific nets, specify the nets by using a net file or by providing a collection that contains the nets. For information about the format of the net file, see "Net File Format" on page 3-19.
- To fix logical DRC violations on pins, use the -drc\_pins option.
  - To fix DRC violations on all pins, set this option to all. To fix DRC violations on specific pins, specify the pins by using an endpoint file or by providing a collection that contains

the pins. For information about the format of the endpoint file, see "Endpoint File Format" on page 3-19.

- To perform register-to-register optimization, use the <code>-register\_to\_register</code> option. By default, when you enable register-to-register optimization, the <code>focal\_opt</code> command fixes setup, hold, and logical DRC violations. You can restrict the optimization to a specific violation type by using the <code>-setup\_endpoints</code>, <code>-hold\_endpoints</code>, <code>-drc\_nets</code>, or <code>-drc\_pins</code> option.
- To perform crosstalk reduction on specific nets, use the -xtalk\_reduction option. Specify the nets on which to perform crosstalk reduction by using a net file or by providing a collection that contains the nets. For information about the format of the net file, see "Net File Format" on page 3-19.
- To perform final stage leakage recovery, use the -power option.
  - When you perform final stage leakage recovery, you must enable exactly one leakage scenario. For information about leakage scenarios, see Chapter 3, "Preparing the Design," in the *IC Compiler Implementation User Guide*.

For more information about final stage leakage recovery, see "Performing Final Stage Leakage-Power Recovery" on page 3-20.

By default, the <code>focal\_opt</code> command uses medium effort to fix the remaining violations. When using medium effort, the <code>focal\_opt</code> command explores more solution spaces than the <code>route\_opt</code> command while fixing the violations, including solutions that exceed the density limit. If medium effort does not fix the remaining violations, you can use high effort (<code>-effort high</code> option), which explores even more solution spaces and uses runtime-expensive accurate signal integrity reestimation. Due to the additional runtime required for high effort, use this only when you have a few remaining violations to close. Note that the <code>-effort</code> option does not apply to final stage leakage recovery.

If your design has remaining violations, and you want to prioritize the fixing of those violations above all other cost priorities, you can use the <code>-prioritize</code> option. When you use the <code>-prioritize</code> option, the <code>focal\_opt</code> command might violate other constraints to fix the prioritized violations. Note that the <code>-prioritize</code> option does not apply to crosstalk reduction or final stage leakage recovery.

If your design is very sensitive to postroute optimization changes, you can limit the optimizations to sizing-only optimizations by specifying the mode with the <code>-size\_only\_mode</code> option. When you specify this option you must select one of the following sizing modes: density-based sizing (<code>density</code>), in-place sizing (<code>in\_place</code>), or footprint-preservation sizing (<code>footprint</code>). Note that the <code>-size\_only\_mode</code> option does not apply to crosstalk reduction or final stage leakage recovery.

If you find that the <code>focal\_opt</code> command leaves unfixed violations, you can enable verbose reporting during optimization by setting the <code>routeopt\_verbose</code> variable. This variable uses

bitwise operation to enable various reporting capabilities. For details about setting this variable, see SolvNet article 032174.

#### **Endpoint File Format**

To fix setup, hold, or logical DRC violations on specific endpoints, you can specify the endpoints in an endpoint file. This file can be either uncompressed or compressed in gzip format. When the file is a gzip file, it must have the .gz file extension.

The following formats are supported for specifying an endpoint:

Endpoint only

```
I_STACK_TOP/I3_STACK_MEM/Stack_Mem_reg_2__1_/D
```

Endpoint with a slack value

```
I_STACK_TOP/I3_STACK_MEM/Stack_Mem_reg_2__1_/D 0.58 0.44 r -0.14
```

By default, when you use this format with the <code>-setup\_endpoints</code> or <code>-hold\_endpoints</code> option, the tool uses the slack values specified in the endpoint file during focal optimization. To use the computed slack values instead, set the <code>focalopt\_endpoint\_margin</code> variable to <code>false</code>.

When you use this format with the <code>-drc\_pins</code> option, the tool ignores the slack information and uses only the pin information.

The best way to generate these lines is by editing the file generated by the report\_constraint command.

#### **Net File Format**

To fix logical DRC violations on specific nets, you must specify the nets in a net file.

The following formats are supported for specifying a net:

Net name only

```
I_STACK_TOP/n342
```

· Net name with a violation

```
I_STACK_TOP/n342 0.70 0.89 -0.19 (VIOLATED)
```

When you use this format with the  $-drc\_nets$  option, the tool ignores the slack information and uses only the net information.

The best way to generate these lines is by editing the file generated by the report\_constraint command.

# **Performing Final Stage Leakage-Power Recovery**

Final stage leakage-power recovery optimizes the leakage power based on the cell\_footprint attribute of the library cells. Ensuring that your design is close to timing closure is a prerequisite for final stage leakage-power recovery.

The final stage leakage-power recovery step considers library cells to have the same footprint if the cells have

- The same operating conditions (P, V, and T)
- Logical equivalence
- The same physical boundary, width, and height, as defined in the FRAM view
- The same cell\_footprint attribute

For information about preparing the logic libraries for final stage leakage-power recovery, see Chapter 3, "Preparing the Design," in the *IC Compiler Implementation User Guide*.

To perform final stage leakage-power recovery on a postroute design,

1. For a multicorner-multimode design, use the set\_scenario\_options command to select the leakage scenario. You can select only a single leakage scenario.

To ensure that you set only one leakage scenario, enter the following commands:

```
icc_shell> set leakage_scenario S1
icc_shell> set_scenario_options -leakage_power false \
    -scenarios [all_active_scenarios]
icc_shell> set_scenario_options -leakage_power true \
    -scenarios $leakage_scenario
```

If you do not have exactly one leakage scenario defined during final stage leakage-power recovery, the tool issues the PSYN-706 error message.

```
Error: There are multiple scenarios or no scenario with set_scenario_options -leakage_power true. (PSYN-706)
```

For more information about selecting the leakage scenarios, see Chapter 3, "Preparing the Design," in the *IC Compiler Implementation User Guide*.

2. If the postroute design has setup, hold, or logical DRC violations, run the focal\_opt command to perform focal optimization to fix these violations.

For more information about the focal\_opt command, see "Performing Focal Optimization" on page 3-17.

3. (Optional) Run the <code>verify\_zrt\_route</code> command to report the routing DRC violations that exist before final stage leakage-power recovery.

Perform this step to validate the cell footprint in the physical libraries by comparing the DRC violations reported before and after final stage leakage-power recovery.

4. Run the focal\_opt -power command to perform postroute focal optimization for leakage-power recovery.

By default, this step uses footprint swapping to improve the leakage power on paths with positive slack. You can control the tradeoff between leakage-power recovery and timing QoR preservation by setting the <code>focalopt\_power\_critical\_range</code> variable. This variable specifies the slack threshold for leakage-power recovery and timing QoR preservation. The <code>focal\_opt\_-power</code> command performs leakage-power recovery only on cells whose worst slack is greater than the power critical range value and preserves the timing QoR such that the worst slack is greater than or equal to the power critical range value.

When you set this variable to a positive number, the command preserves timing QoR with positive slack and performs less leakage-power recovery. When you set this variable to a negative number, the command performs more aggressive leakage-power recovery and allows timing degradation. For multicorner-multimode designs, the tool uses only the leakage scenario for leakage-power recovery, but it considers all active scenarios for timing QoR. Note that this command does not perform placement legalization or ECO routing after the leakage-power recovery.

When you use the <code>-power</code> option, you cannot use any other options with the <code>focal\_opt</code> command.

When you run the focal\_opt -power command, pay attention to the FOPT-28 and FOPT-29 messages in the log file.

Information: Optimizing leakage power with 3 voltage thresholds (FOPT-028).

Warning: Libcells cell\_name1 and cell\_name2 have same footprint but different pin geometry - eco route may be required after Leakage optimization (FOPT-029).

These information and warning messages list the library cells that have issues with the cell\_footprint attributes.

5. (Optional) Run the <code>verify\_zrt\_route</code> command to report the routing DRC violations that exist after final stage leakage-power recovery.

Compare the reported violations to those reported before final stage leakage-power recovery. If the number of violations reported after running the <code>focal\_opt -power</code> command is more than the number of violations reported before, it implies that the physical libraries have issues such as dissimilar pin shape that result in additional DRC violations.

The following example script shows how to perform final stage leakage-power recovery for a multicorner-multimode design after routing optimization:

```
# Set one scenario as the leakage corner
set_scenario_options -leakage_power false \
    -scenarios [all_active_scenarios]
set_scenario_options -leakage_power true -scenarios S1
# Fix setup, hold, and logical DRC violations
focal_opt -setup_endpoints all
focal_opt -hold_endpoints all
focal_opt -drc_nets all
# Perform final stage leakage-power recovery
focal_opt -power
```

# **Routing Signal Nets by Using Automatic Routing**

Before you use automatic routing to route the signal nets, you must define the routing options as described in "Setting Routing Options" on page 2-13.

To run automatic routing, use the <code>route\_auto</code> command (or choose Route > Auto Route in the GUI). By default, the <code>route\_auto</code> command sequentially invokes global routing, track assignment, and detail routing.

Table 3-5 describes the route\_auto command options. For more information, see the man page.

Table 3-5 route auto Command Options

| Command option                                                                      | Description                                                                                                                       |
|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| -no_global ("Global route" check box in Run section in the GUI)                     | Skips global routing.                                                                                                             |
| -no_track ("Track assignment" check box in Run section in the GUI)                  | Skips track assignment.                                                                                                           |
| -no_detail<br>("Detail route" check box in Run section<br>in the GUI)               | Skips detail routing.                                                                                                             |
| -save_after_global_route<br>("Global route" check box in Run<br>section in the GUI) | Controls whether the design is saved after global routing. When specified, the tool saves the design in a CEL view named auto_GR. |

Table 3-5 route\_auto Command Options (Continued)

| Command option                                                                   | Description                                                                                                                                                                                                                           |
|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -save_after_track<br>("Track assignment" check box in Run<br>section in the GUI) | Controls whether the design is saved after track assignment.  When specified, the tool saves the design in a CEL view                                                                                                                 |
|                                                                                  | named auto_TA.                                                                                                                                                                                                                        |
| -save_after_detail_route                                                         | Controls whether the design is saved after detail routing.                                                                                                                                                                            |
| ("Detail route" check box in Run section in the GUI)                             | When specified, the tool saves the design in a CEL view named auto_DR.                                                                                                                                                                |
| -search_repair_loop int                                                          | Specifies the maximum number of search and repair loops.                                                                                                                                                                              |
| ("Maximum Search & Repair cycles"                                                | You must specify a value between 0 and 500.                                                                                                                                                                                           |
| box in the GUI)                                                                  | The default is 0.                                                                                                                                                                                                                     |
| -effort minimum   low   medium                                                   | Specifies the effort level for automatic routing.                                                                                                                                                                                     |
| high                                                                             | The default is medium.                                                                                                                                                                                                                |
| (Effort radio buttons in the GUI)                                                |                                                                                                                                                                                                                                       |
| -num_cpus int  ("Number of CPUs" box in the GUI)                                 | Specifies the number of CPUs to use for distributed routing. You must specify a value between 1 and 63. For information about setting up for distributed routing, see "Enabling Distributed Routing" on page 2-18.  The default is 1. |

# **Running Individual Routing Steps**

After you have specified your routing options, you can debug your design or monitor each routing step by performing each routing step individually. Individual routing steps are explained in the following sections:

- Global Routing
- Track Assignment
- Detail Routing
- Search and Repair
- Wire and Via Optimization

# **Global Routing**

Global routing maps general pathways through the design for each unrouted signal net and clock net.

To perform global routing, use the <code>route\_global</code> command (or choose Route > Global Route in the GUI). By default, the classic router performs medium-effort global routing. To change the effort level, use the <code>-effort</code> option.

The global router performs the following tasks:

- Divides the chip into square units called global routing cells.
  - The height and width of the global routing cells are determined by using the average height of the standard cells.
- Assigns nets to the global routing cells through which they pass.
  - For each global routing cell, the routing capacity is calculated according to the blockages, pins, and routing tracks inside the cell. Although the nets are not assigned to the actual wire tracks during global routing, the number of nets assigned to each global routing cell is noted.
- Determines the demand for routing tracks, both horizontally and vertically, through each global routing cell, based on the locations of the cell pins and their respective unrouted connections.
  - The global router considers spacing and wide-wire variable routing rules, as well as shielding variable routing rules, when calculating congestion.
- Reports the overflow for each metal layer.
  - The overflow is the number of tracks still needed after the global router assigns nets to the available wire tracks in a global routing cell. It is calculated as the number of tracks needed minus the number of available tracks in a given direction through a global routing cell. The higher the overflow value, the worse the overflow. A negative overflow value, which is referred to as an underflow, indicates that all required routes can be accommodated. If your design has positive overflow values, you can analyze the congestion issues by using the congestion report and congestion map described in "Analyzing Congestion" on page 3-27.

#### **Global Routing During Design Planning**

During design planning you can perform prototype global routing by using the route\_zrt\_global -effort minimum command.

```
icc_shell> route_zrt_global -effort minimum
```

If you are using the hierarchical flow, set the <code>-plan\_group\_aware\_routing</code> option of the <code>set\_fp\_flow\_strategy</code> command to <code>true</code> to enable plan-group-aware global routing before running the <code>route\_global</code> command. When you enable plan-group-aware global routing, the classic router routes all the nets in the design and preserves the hierarchy and pin constraints. You can increase the plan-group-aware routing speed by routing only the top-level nets. To do this, set the <code>-top\_level\_routing\_only</code> option of the <code>set\_fp\_flow\_strategy</code> command to <code>true</code>. When plan-group-aware global routing is not enabled, which is the default, the classic router ignores the plan groups and routes the design as flat.

```
icc_shell> set_fp_flow_strategy -plan_group_aware_routing true
icc_shell> route_global -effort minimum
```

# Track Assignment

Before you perform detail routing, run track assignment to specify which tracks within each global routing cell are to be used for each net. Track assignment operates on the entire design at once; it can make long routes straight and reduce the number of vias, whereas the detail routing routes a small area at a time.

After track assignment finishes, all nets are routed, but not very carefully. There are many violations, particularly where the routing connects to pins. Detail routing works to correct those violations.

To perform track assignment, use the <code>route\_track</code> command (or choose Route > Track Assignment in the GUI).

# **Detail Routing**

Detail routing uses the general pathways suggested by global routing and track assignment to route the nets (paths and contacts).

To perform detail routing, use the route\_detail command (or choose Route > Detail Route in the GUI).

By default, standalone detail routing

- Performs track assignment before detail routing
   To skip track assignment, use the -track assign skip option.
- Does not have a runtime limit

If you need to limit the runtime, specify the maximum number of minutes by using the -run\_time\_limit option.

Uses one CPU

If you are performing distributed routing, specify the number of CPUs by using the -num\_cpus option. For information about setting up for distributed routing, see "Enabling Distributed Routing" on page 2-18.

Does not perform any search and repair passes

To change the maximum number of search and repair passes, use the -search\_repair\_loop option.

# **Search and Repair**

During search-and-repair routing passes, the classic router searches for DRC violations and reroutes wires in an effort to avoid violations. The classic router does not add metal stubs on frozen nets to fix DRC violations, even when the nets have DRC violations.

To run standalone search-and-repair routing, use the <code>route\_search\_repair</code> command (or choose Route > Search-and-Repair Route in the GUI). By default, the <code>route\_search\_repair</code> command performs 50 search-and-repair passes. To change the maximum number of passes, use the <code>-loop</code> option.

If you need to limit the search-and-repair runtime, specify the maximum number of minutes by using the <code>-run\_time\_limit</code> option. You can reduce the turnaround time for running search-and-repair routing by using distributed routing. To use distributed routing, specify the number of CPUs by using the <code>-num\_cpus</code> option. For information about setting up for distributed routing, see "Enabling Distributed Routing" on page 2-18.

For more information about the route\_search\_repair command, see the man page.

# Wire and Via Optimization

To optimize wires and vias, use the <code>optimize\_wire\_via</code> command (or choose Route > Optimize Wire Via in the GUI). By default, the <code>optimize\_wire\_via</code> command performs 20 search-and-repair passes. To change the maximum number of search-and-repair passes, use the <code>-search</code> repair <code>loop</code> option.

If you need to limit the wire and via optimization runtime, specify the maximum number of minutes by using the <code>-run\_time\_limit</code> option. You can reduce the turnaround time for running wire and via optimization by using distributed routing. To use distributed routing, specify the number of CPUs by using the <code>-num\_cpus</code> option. For information about setting up for distributed routing, see "Enabling Distributed Routing" on page 2-18.

For more information about the optimize\_wire\_via command, see the man page.

# **Analyzing Congestion**

To help you analyze the congestion in your design, the tool can generate both an ASCII congestion report, as shown in Example 3-1 and a visual congestion map, as shown in Figure 3-1 on page 3-30. You can generate the congestion report and congestion map for each routing stage: global routing, track assignment, and detail routing. The more routing stages that have been completed, the more accurate the congestion information is; however, the harder it is to fix the congestion issues.

# **Generating a Congestion Report**

To generate a congestion report, run the report\_congestion command.

```
icc_shell> report_congestion
```

By default, this command generates a global route congestion report by running global routing and reports a summary of the overflow information for the entire design, as shown in Example 3-1.

#### Example 3-1 Default Global Route Congestion Report

Information: Reporting global route congestion data from Milkyway...

```
Both Dirs: Overflow = 39 \text{ Max} = 8 (1 \text{ GRCs}) \text{ GRCs} = 14 (0.26\%) H routing: Overflow = 6 \text{ Max} = 2 (2 \text{ GRCs}) \text{ GRCs} = 4 (0.07\%) V routing: Overflow = 33 \text{ Max} = 8 (1 \text{ GRCs}) \text{ GRCs} = 10 (0.18\%)
```

In the congestion report, the Overflow value is the total number of wires in the design that do not have a corresponding track available; the Max value corresponds to the highest number of overutilized wires in a single global routing cell; and the GRCs value is the total number of overcongested global routing cells in the design.

The generated congestion information, but not the global routing results, is stored in the Milkyway design database. To display the congestion report in the design database instead of regenerating a congestion report, use the <code>-no\_reroute</code> option when you run the <code>report\_congestion</code> command.

You can report additional information in the congestion report by using the options shown in Table 3-6.

Table 3-6 Generating Additional Congestion Information

| Option              | Description                                                                                                                                                              |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -grc_based          | Provides detailed information about the 10 worst global routing cells for each category: total, horizontal, and vertical.                                                |
| -grc_number         | Provides detailed information about the specified number of worst global routing cells for each category.                                                                |
| -overflow_threshold | Provides detailed information about the global routing cells that exceed the specified overflow threshold, up to a maximum of 10 global routing cells for each category. |
| -by_layer           | Generates a congestion report for each routing layer. The type of report, summary or GRC-based, generated for each layer depends on the other options that you specify.  |

Example 3-2 shows an example of a congestion report with detailed information about the global routing cells. This same format is used when you specify the <code>-grc\_based</code>, <code>-grc\_number</code>, or <code>-overflow\_threshold</code> options; the only difference is the number of global routing cells reported in each category.

#### Example 3-2 Global Route Congestion Report With Global Routing Cell Details

Information: Reporting global route congestion data from Milkyway... There are 2704 GRCs (Global Route Cell) in this design \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* 14 GRCs with overflow: 4 with H overflow and 10 with V overflow ++++++ Top 10 congested GRCs ++++++ GRC {624345 676005 650175 701835}: H routing capacity/demand = 81/81 (occupy rate = 1.00), V routing capacity/demand = 54/62 (occupy rate = 1.15) with overflow 8 GRC {624345 701835 650175 727665}: H routing capacity/demand = 74/74 (occupy rate = 1.00), V routing capacity/demand = 54/59 (occupy rate = 1.09) with overflow 5 GRC {676005 391875 701835 417705}: H routing capacity/demand = 12/14 (occupy rate = 1.17), V routing capacity/demand = 3/3 (occupy rate = 1.00) with overflow 2 +++++++ Top 10 horizontally congested GRCs +++++++ GRC {650175 391875 676005 417705}: H routing capacity/demand = 12/14 (occupy rate = 1.17) with overflow 2 GRC {676005 391875 701835 417705}: H routing capacity/demand = 12/14 (occupy rate = 1.17) with overflow 2 GRC {727665 882645 753495 908475}: H routing capacity/demand = 91/91 (occupy rate = 1.00) ++++++ Top 10 vertically congested GRCs +++++++ GRC {624345 676005 650175 701835}: V routing capacity/demand = 54/62 (occupy rate = 1.15) with overflow 8 GRC {624345 701835 650175 727665}: V routing capacity/demand = 54/59 (occupy rate = 1.09) with overflow 5

You can generate a congestion report for a portion of the design by using the -coordinates option to specify a rectangular area or the -polygon option to specify a rectilinear area.

You can also generate congestion reports based on the track assignment and detail routing in the design by setting the <code>-routing\_stage</code> option to <code>track</code> or <code>detail</code>, respectively. When you generate these reports, the tool does not run track assignment or detail routing; it uses the existing information in the design. If the track assignment or detail route information does not already exist in the design database, the tool issues an error message and does not generate a congestion report.

For more information about the report\_congestion command, see the man page.

1

# **Generating a Congestion Map**

To display the global route congestion map, choose Route > Global Route Congestion Map in the GUI. If the design database contains global route congestion information, the tool generates the congestion map based on this information; otherwise, you must click Reload to generate the congestion map. When you click Reload, the tool opens a dialog box that contains the following command:

```
report_congestion -grc_based -by_layer -routing_stage global
```

When you click OK in this dialog box, the tool generates a new congestion map. If you want to use different options for the report\_congestion command, you can modify this command before clicking OK.

Figure 3-1 shows an example of a congestion map.

Figure 3-1 Global Route Congestion Map



The congestion map shows the borders between global routing cells highlighted with different colors that represent different levels of overflow. The overflow values shown in the congestion map are determined by combining the overflow and underflow of all selected layers; they do not represent the maximum overflow values.

By default, all metal layers are selected in the congestion map. To display the congestion map for a subset of layers, select or deselect the layers on the Map Mode panel. For example, if the global routing report shows that the maximum overflow occurs on metal layer 2, you can deselect all layers, except for metal 2, to display only the metal 2 congestion.

The Map Mode panel also displays a histogram showing the number of global routing cells in different ranges (bins) of overflow values for the selected layers. You can select which bins to display in the congestion map by selecting or deselecting them on the Map Mode panel.

If the design shows congested areas, zoom into the congested area to see the overflow number on the global routing cell. For example, in Figure 3-2, the red highlight on the edge of the global routing cell shows 18/9. This means there are 9 wire tracks available, but 18 tracks are needed.



Figure 3-2 Global Route Overflow on Global Routing Cell

You can also generate congestion maps based on the track assignment and detail routing in your design. To generate a congestion map based on track assignment, choose Route > Track Assign Congestion Map in the GUI. To generate a congestion map based on detail routing, choose Route > Detail Route Congestion Map in the GUI. When you generate these congestion maps, the tool does not run track assignment or detail routing; it uses the existing information in the design. If the track assignment or detail route information does not already exist in the design database, the tool issues an error message and does not generate a congestion map.

# **Shielding Nets**

The router shields routed nets by generating shielding wires that are based on the shielding widths and spacing defined in the shielding rules. In addition to shielding nets on the same layer, you also have the option to shield one layer above or one layer below or the layer above and the layer below. Shielding above or below the layer is called *coaxial shielding*. Coaxial shielding provides even better signal insulation than same-layer shielding, but it uses more routing resources. Figure 3-3 shows an example of coaxial shielding.

Figure 3-3 Coaxial Shielding



You can perform shielding either before or after signal routing. Shielding before signal routing, which is referred to as preroute shielding, provides better shielding coverage but can result in congestion issues during signal routing. Preroute shielding is typically used to shield critical clock nets. Shielding after signal routing, which is referred to as postroute shielding, has a very minimal impact on routability, but provides less protection to the shielded nets.

Before you perform shielding, you must

1. Define the shielding rules.

To define shielding rules, use the <code>-shield\_spacings</code> and <code>-shield\_widths</code> options of the <code>define\_routing\_rule</code> command. For example, to specify a shielding rule that uses spacing of 0.1 microns and width of 0.1 microns for metal1 through metal5 and spacing of 0.3 microns and width of 0.3 microns for metal6, enter the following command:

```
icc_shell> define_routing_rule shield_rule \
   -shield_widths {M1 0.1 M2 0.1 M3 0.1 M4 0.1 M5 0.1 M6 0.3} \
   -shield_spacings {M1 0.1 M2 0.1 M3 0.1 M4 0.1 M5 0.1 M6 0.3}
```

For more information about the define\_routing\_rule command, see "Defining Nondefault Routing Rules" on page 2-7.

#### 2. Assign shielding rules to the nets to be shielded.

To avoid congestion issues and achieve the best balance of DRC convergence and timing closure, apply shielding rules only to high-frequency or critical clock nets and apply double-spacing rules to the lower-frequency clock nets.

Use the set\_clock\_tree\_options command to assign shielding rules to clock nets. For signal nets, use the set\_net\_routing\_rule command to assign the shielding rules.

#### Note:

The set\_clock\_tree\_options command assigns shielding rules to clock nets only before clock tree synthesis. After clock tree synthesis, you must use the set\_net\_routing\_rule command to assign shielding rules to clock nets.

For more information about these commands, see "Applying Nondefault Routing Rules" on page 2-8.

To shield nets with defined rules, use the <code>create\_auto\_shield</code> command (or choose Route > Create Shield in the GUI).

By default, the <code>create\_auto\_shield</code> command performs same-layer shielding on all nets with predefined shielding rules. The shielding wires are tied to ground, standard cell power and ground pins, and standard cell rails.

To explicitly specify the nets on which to perform shielding, use the <code>-nets</code> option. To perform coaxial shielding, use the <code>-coaxial\_above</code> and <code>-coaxial\_below</code> options. To tie the shielding wires to a named power or ground net, use the <code>-with\_ground</code> option. To prevent connections to the standard cell power and ground pins, use the <code>-ignore\_shielding\_net\_pins</code> option. To prevent connections to the standard cell rails, use the <code>-ignore\_shielding\_net\_rails</code> option.

For example, to perform coaxial shielding below the shielded net segment layer on the clock nets and tie the shielding wires to VSS, enter

```
icc_shell> create_auto_shield -nets $clock_nets \
    -coaxial below true -with ground VSS
```

# **Performing ECO Routing**

Whenever you modify the nets in your design, you need to run engineering change order (ECO) routing to reconnect the routing.

To run ECO routing, use the route\_eco command (or choose Route > ECO Route in the GUI).

By default, the ECO router connects open nets and then fixes design rule violations in the design. All the open nets are run sequentially through global routing, track assignment, and detail routing. The ECO router can reroute existing wires to fix DRC violations. You can modify the default behavior by using the route\_eco command options.

Table 3-7 describes the route\_eco command options. For more information, see the man page.

Table 3-7 route\_eco Command Options

| Command option                                                             | Description                                                                                                                                                  |
|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -no_global<br>("Global route" check box in Run section<br>in the GUI)      | Skips global routing.                                                                                                                                        |
| -no_track<br>("Track assignment" check box in Run<br>section in the GUI)   | Skips track assignment.                                                                                                                                      |
| -no_detail<br>("Detail route" check box in Run section<br>in the GUI)      | Skips detail routing.                                                                                                                                        |
| -auto<br>(Auto check box in the Run section in the<br>GUI)                 | Enables automatic region-based ECO routing.  You must use this option with the <code>-region_based</code> option.                                            |
| -region_based string ("Region based nets filename" box in the GUI)         | Specifies the name of the file that contains the list of nets on which to perform region-based ECO routing.  You must use this option with the -auto option. |
| -search_repair_loop int  ("Maximum Search & Repair cycles" box in the GUI) | Specifies the maximum number of search and repair loops. You must specify a value between 0 and 500. The default is 20.                                      |

Table 3-7 route\_eco Command Options (Continued)

| Command option                                                                                                      | Description                                                                                                                                                                                                                           |
|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -reroute any_nets   modified_nets_only   modified_nets_first_then_others  ("Reroute nets" radio buttons in the GUI) | Controls which nets can be rerouted to fix DRC violations.  The default is any_nets.                                                                                                                                                  |
| -utilize_dangling_wires ("Utilize dangling wires" check box in the GUI)                                             | Enables the reuse of existing dangling routes to fix open nets.                                                                                                                                                                       |
| -freeze_routing_on_layer list_of_layers ("Freeze routing on layers" list in the GUI)                                | Prevents routing changes on the specified layers.                                                                                                                                                                                     |
| -freeze_vias_on_frozen_metal<br>("Freeze vias on frozen metal" check box<br>in the GUI)                             | Freezes vias on frozen metal layers.                                                                                                                                                                                                  |
| -num_cpus int  ("Number of CPUs" box in the GUI)                                                                    | Specifies the number of CPUs to use for distributed routing. You must specify a value between 1 and 63. For information about setting up for distributed routing, see "Enabling Distributed Routing" on page 2-18.  The default is 1. |

# **Reporting Cell Placement and Routing Statistics**

You can report on cell placement and routing statistics to help you determine whether to perform further optimizations to improve timing. For example, if the statistics show that an area has high congestion, an additional optimization might not have room to add or size up standard cells.

To view the place and route summary report, run the report\_design\_physical -verbose command.

# **Verifying the Routed Design**

After you have completed routing with the classic router, you can check the design for routing design rule violations.

#### Note:

The classic router uses center lines to determine connectivity. If your design contains wires with zero wire extension, the <code>verify\_route</code> command might report open and spacing violations due to these zero extension wires. To fix this problem, use the <code>convert\_wire\_ends</code> command to convert all wires with zero extension into wires with half-width extensions. If the <code>convert\_wire\_ends</code> command cannot convert a wire, it issues a warning message and removes the wire from the design cell. Because the <code>convert\_wire\_ends</code> command modifies the wire end information and, in some cases, removes wires, write commands such as <code>write\_def</code> generate output files that are different from the original input files. For more information about the <code>convert\_wire\_ends</code> commands, see the man page.

The IC Compiler tool provides the following methods for verifying the routed design:

 Use the IC Validator or Hercules tool to check the routing design rules defined in the foundry runset.

To use this method, run the  $signoff\_drc$  command or choose Verification > Signoff DRC in the GUI.

#### Note:

An IC Validator or Hercules license is required to run the signoff drc command.

 Use the Hercules tool to check the routing design rules defined in the Milkyway technology file.

To use this method, run the  $verify\_drc$  command or choose Verification > DRC in the GUI.

#### Note:

A Hercules license is required to run the verify drc command.

 Use the IC Compiler DRC engine to check the routing design rules defined in the Milkyway technology file.

To use this method, run the <code>verify\_route</code> command or choose Route > Verify Route in the GUI.

Import the DRC results from the Calibre tool.

The following sections describe these methods.

## Using the signoff\_drc Command

Signoff design rule checking runs the IC Validator or Hercules tool within the IC Compiler tool to check the routing design rules defined in the foundry runset. To perform signoff design rule checking, run the signoff\_drc command (or choose Verification > Signoff DRC in the GUI).

#### Note:

An IC Validator or Hercules license is required to run the signoff\_drc command.

To use the signoff\_drc command to perform design rule checking,

- Set up the validation tool environment.
- Set up the physical signoff options.
- Run the signoff\_drc command (or choose Verification > Signoff DRC in the GUI).

The following sections describe these tasks.

## **Setting Up the Validation Tool Environment**

You can use either the IC Validator or Hercules tool to check the routing design rules with the signoff\_drc command.

## **Setting Up the IC Validator Environment**

To use the IC Validator tool when running the <code>signoff\_drc</code> command, you must have an IC Validator license, and you must specify the location of the IC Validator executable by setting the <code>ICV\_HOME\_DIR</code> environment variable. You can set this variable in your .cshrc file. To specify the location of the IC Validator executable, use commands similar to those shown in the following example:

```
setenv ICV_HOME_DIR /root_dir/icv
set path = ($path $ICV_HOME_DIR/bin/AMD.64)
```

You must ensure that the version of the IC Validator executable that you specify is compatible with the IC Compiler version that you are using.

For more information about the IC Validator tool, see the IC Validator documentation, which is available on SolvNet.

## **Setting Up the Hercules Environment**

To use the Hercules tool when running the <code>signoff\_drc</code> command, you must have a Hercules license, and you must specify the location of the Hercules executable by setting the <code>HERCULES\_HOME\_DIR</code> environment variable. You can set this variable in your .cshrc file. For example,

```
setenv HERCULES_HOME_DIR /root_dir/hercules
set path = ($path $HERCULES_HOME_DIR/bin/AMD.64)
```

You must ensure that the version of the Hercules executable that you specify is compatible with the IC Compiler version that you are using. For more information about the Hercules tool, see the Hercules documentation, which is available on SolvNet.

## **Setting Up the Physical Signoff Options**

To set up the physical signoff options, use the set\_physical\_signoff\_options command (or choose Verification > Set Physical Signoff Options in the GUI). The settings that you specify are saved in the Milkyway design library.

Table 3-8 shows the physical signoff options that apply to the signoff\_drc command.

Table 3-8 Physical Signoff Options for signoff\_drc

| Command option                                                   | Description                                                                                                                                                                                   |
|------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -exec_cmd icv   hercules  ("Executable name" box in the GUI)     | Specifies the validation tool to use for design rule checking (optional).                                                                                                                     |
| (                                                                | If you do not specify this option, the signoff_drc command uses the value stored in the Milkyway design library. If there is no value stored in the Milkyway design library, an error occurs. |
| -drc_runset file_name (DRC box in the GUI "Foundry runset" area) | Specifies the foundry runset to use for design rule checking (required).                                                                                                                      |
| -mapfile file_name                                               | Specifies the layer mapping file (optional).                                                                                                                                                  |
| ("Layer mapping file" box in the GUI)                            | For more information, see the next section, "Defining the Layer Mapping Between Milkyway and the Runset File."                                                                                |

To report the current settings for the physical signoff options, use the report\_physical\_signoff\_options command.

#### Defining the Layer Mapping Between Milkyway and the Runset File

In general, the Milkyway technology file and the runset file used by the IC Validator or Hercules tool use the same layer numbers. If they do not, you must supply a layer-mapping file to map the Milkyway layers to the layers used in the runset file.

The signoff\_drc command accepts a layer-mapping file in IC Validator, Hercules, or Milkyway format.

• The syntax of the mapping information in an IC Validator or Hercules mapping file is

Milkyway\_layer\_list > runset\_layer\_list

The rules for specifying the layer lists are

- Each layer in a layer list must be separated by a space. Or, if specified in a range, the range must consist of a starting layer and an ending layer joined by a dash (-).
- Generally, parentheses should surround the layer list. However, you can omit parentheses if you specify only one layer.

You can include comments in a layer mapping file by preceding the comment with a pound sign (#). All text that follows a pound sign on a given line is a comment.

The syntax of the mapping information in a Milkyway mapping file is

```
MilkywayObjType MilkywayLayer[:DataType] RunsetLayer[:RunsetDataType]
```

The *MilkywayObjType* argument is a string of one to three characters that identifies the Milkyway objects to be translated. The required first character is the code for the type of Milkyway object to be translated: A for all, T for text, or D for data. The optional second character specifies the net type, such as S for signal, P for power, or G for ground. An optional third character specifies the pin code. The Milkyway layer is a name or an integer. The runset layers and data types are integers.

You can add a comment to the file by inserting a semicolon. Text is ignored from the semicolon to the end of the line.

You can save the Milkyway layer mapping file in the Milkyway design library by using the set\_stream\_layer\_map\_file -format out command. When the Milkyway design library contains a layer mapping file, it defines the default mapping. The layer mapping file specified by the set\_physical\_signoff\_options -mapfile option overrides the layer mapping file saved in the Milkyway design library.

For more information about the Milkyway mapping file, see the "Layer Mapping File: Milkyway to GDSII or OASIS" section in Chapter 3 of the *Library Preparation for IC Compiler User Guide*.

## **Performing Distributed Design Rule Checking**

By default, the <code>signoff\_drc</code> command uses a single process to perform design rule checking. To reduce the turnaround time used for design rule checking, you can use distributed processing. To enable distributed processing, you must define the distributed processing configuration by using the <code>set host options</code> command.

If you have defined more than one distributed processing configuration with the  $set\_host\_options$  command, the  $signoff\_drc$  command selects the IC Validator processing method in the following order of priority:

1. Job submission through a user-defined distributed processing script

To enable job submission using your own script with the set\_host\_options command, use the -submit\_command option to specify the location of your job submission script. For example, to specify a configuration named custom4 that enables a maximum of four processes using your job submission script, enter the following command:

```
icc_shell> set_host_options -name custom4 -num_processes 4 \
    -submit_command /usr/local/bin/my_submit_command
```

2. Job submission through the Load Sharing Facility (LSF) or the Sun Grid Engine (SGE)

To enable LSF or SGE job submission with the set\_host\_options command, use the -pool option to specify the mode and the -num\_processes option to specify the maximum number of processes.

For example, to specify a configuration named lsf4 that enables a maximum of four processes using LSF, enter the following command:

```
icc_shell> set_host_options -name lsf4 -pool lsf -num_processes 4
```

To specify a configuration named grd4 that enables a maximum of four processes using SGE, enter the following command:

```
icc_shell> set_host_options -name grd4 -pool grd -num_processes 4
```

3. Distributed processing on the specified hosts

To enable distributed processing with the set\_host\_options command, specify the hosts to use and use the -num\_processes option to specify the maximum number of processes on each host. For example, to specify a configuration named dp4 that enables a maximum of four processes, with a maximum of two processes each on machineA and machineB, enter the following command:

4. Multithreading

To enable multithreading on the current machine with the set\_host\_options command, use the -max\_cores option to specify the number of threads. For example, to specify a

configuration named mt4 that enables a maximum of four threads on the current machine, enter the following command:

```
icc_shell> set_host_options -name mt4 -max_cores 4
```

To ensure that you are using the intended distributed processing configuration, remove the current configurations by using the <code>remove\_host\_options</code> command before defining the distributed processing configuration for the <code>signoff\_drc</code> command. To report the current distributed processing configurations, use the <code>report\_host\_options</code> command.

For more information about the set\_host\_options command, see Chapter 2, "Working With the IC Compiler Tool," in the IC Compiler Implementation User Guide.

## Running the signoff\_drc Command

By default, the <code>signoff\_drc</code> command uses the FRAM view to check all cell types (standard cells, macro cells, and I/O pad cells) on all routing layers of the entire chip for all rules specified in the foundry runset. To use the <code>CEL</code> view instead of the FRAM view, use the <code>-read\_cel\_view</code> option or select the "CEL view" option in the GUI. Using the CEL view can expose problems that are masked by the FRAM view abstraction.

#### Note:

The signoff\_drc command uses the on-disk design information, not the design information in memory. You must save the current state of the design before running the signoff\_drc command.

You can specify additional options for the Hercules or IC Validator command line by using the <code>-user\_defined\_options</code> option when you run the <code>signoff\_drc</code> command. The string that you specify in this option is added to the command line used to invoke design rule checking in the Hercules or IC Validator tool. The IC Compiler tool does not perform any checking on the specified string.

By default, the IC Validator tool checks for both top-level and child-level errors and reports a maximum of 1000 DRC errors per rule. To ignore child-level errors, use the -ignore\_child\_cell\_errors option. You can override the maximum error count by using the -max\_errors\_per\_rule option when you run the signoff\_drc command.

You can restrict the design rule checking to specific areas of the chip, to specific design rules, and to specific layers.

- To restrict the checking to specific areas of the chip,
  - o If you are using the command line, use the <code>-bounding\_box</code> option to specify the coordinates of each area to check. To exclude checking in specific areas, use the <code>-excluded\_bounding\_boxes</code> option. For either option, you can specify multiple areas by specifying the coordinates for each area.
  - If you are using the GUI, specify the coordinates for each area to check in the
     "Included bounding boxes" list and specify the coordinates for each area to exclude

from checking in the "Excluded bounding boxes" list. To specify an area, either draw the bounding box or enter the x- and y-coordinates of the box. For each area, you can also enable or disable snapping. If snapping is enabled, you can specify that the bounding box should snap to the minimum grid (the default), placement site, routing track, middle routing track, or user grid.

- To restrict the checking to specific rules,
  - o To check only the specified rules, specify the rules in the <code>-select\_rule</code> option (or in the Pattern box in the "To use" section of the Rules area in the GUI).
  - o To exclude checks for specific rule, specify the rules in the <code>-unselect\_rule</code> option (or in the Pattern box in the Excluded section of the Rules area in the GUI).

In either case, you specify the rules by specifying a matching pattern for the rule names. The rule names are specified in the COMMENT section in the runset file. You can use these options together to customize the set of rules checked by the <code>signoff\_drc</code> command.

For example, to restrict the signoff\_drc command to route validation, select the metal layer rules and exclude the metal density rules.

- To restrict the checking to specific layers,
  - Specify the layers in the -select\_layers option (or in the list associated with the "Selected layers" radio button in the "Check DRC violations on" area in the GUI).
- To restrict the checking to specific cell types,
  - o Specify the cell types to exclude in the <code>-excluded\_cell\_types</code> option (or select the associated check box in the "Excluded cell types" area in the GUI).

After you complete design rule checking on the routing layers, you can perform a quick design rule check on the Milkyway database by rerunning the <code>signoff\_drc</code> command with the <code>-check\_all\_layers</code> option. If you are using the GUI, set this option by selecting the "All runset layers (routing and device layers)" radio button in the "Check DRC violations on" area. When you use this option, the design information comes from the CEL view and the validation tool checks all layers, including the nonrouting layers.

The signoff\_drc command creates a Milkyway error view that you can use to report or display the DRC violations. By default, the error view generated by the signoff\_drc command is saved in a file called *design\_*sdrc.err. You can control this name by using the -error\_view option (or the "Error cell name" box in the GUI).

To make it easier to view specific violations in the error browser, you can enable error categorization for the generated error view. When you enable this feature, the violations in the error view are marked with their associated net type and route type. You can use these markings to filter the violations displayed in the error browser. To enable this feature, use the -categorize\_errors true option when you run the signoff\_drc command. Note that

using this feature slightly increases the runtime for the signoff\_drc command. For information about using the error view to debug DRC violations, see "Analyzing DRC Violations" on page 3-47.

In addition to the error view, the signoff\_drc command generates the following files, which you can use for debugging, and places them in a directory called signoff\_drc\_run under the current working directory:

design.errsum or design.LAYOUT\_ERRORS

These files contain an error summary report.

sdrc.ev

This file contains the runset file, including any options added by the signoff\_drc command.

sdrc.log

This file contains any errors that occurred during the signoff\_drc run.

./run\_details/design.sum

This file contains the detailed log file from the validation tool.

You can control the directory location by using the <code>-run\_dir</code> option (or the "Run directory" box in the GUI). You can specify either a relative path, in which case the directory is created under the current working directory, or an absolute path.

# Using the verify\_drc Command

If you do not have a foundry runset, you can use the  $verify\_drc$  command to perform design rule checking with a runset based on the design rules defined in the Milkyway technology file.

#### Note:

The <code>verify\_drc</code> command does not check design rules for technologies at the 45-nm process node and below. To check design rules for these technologies, you must use the <code>signoff drc</code> command.

For information about the routing design rules and the technology file attributes that define them, see the *IC Compiler Technology File and Routing Rules Reference Manual*.

The <code>verify\_drc</code> command generates a Hercules DRC runset based on the design rules defined in the Milkyway technology file, and then runs the Hercules tool to check for DRC violations. A Hercules license is required to run the <code>verify\_drc</code> command. For more information about the Hercules tool, see the Hercules documentation, which is available on SolvNet.

To use the verify\_drc command to perform design rule checking,

- Set up the Hercules environment.
   For information about setting up the Hercules environment, see "Setting Up the Validation Tool Environment" on page 3-37.
- Run the verify\_drc command.

By default, the <code>verify\_drc</code> command checks and reports the DRC violations for the entire design. To perform these checks only in a specific region, specify the coordinates of the region by using the <code>-selected\_area</code> option (or by specifying the coordinates in the "Selected area" box in the "DRC Area" tab in the GUI). To perform these checks for the entire design, except for a specific region, specify the coordinates of the excluded region by using the <code>-excluded\_area</code> option (or by specifying the coordinates in the "Whole chip except area" box in the "DRC Area" tab in the GUI).

Table 3-9 lists the design rules checked by the verify\_drc command.

Table 3-9 Design Rules Checked by verify\_drc

| Rule                                                                                                                                          | Checked by default | Command option to enable or disable                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-------------------------------------------------------------------------------|
|                                                                                                                                               |                    | (Check box in the "DRC Rules" tab in GUI)                                     |
| Minimum and maximum width                                                                                                                     | Yes                | -ignore_width                                                                 |
|                                                                                                                                               |                    | ("Minimum and maximum width rule")                                            |
| Metal spacing (includes                                                                                                                       | Yes                | -ignore_spacing                                                               |
| minimum spacing, same-net<br>spacing, fat metal spacing, the<br>fat metal parallel length rule,<br>and the fat metal extension<br>range rule) |                    | ("All spacing related rules")                                                 |
| Minimum area                                                                                                                                  | Yes                | -ignore_area                                                                  |
|                                                                                                                                               |                    | ("Minimum area")                                                              |
| Metal density                                                                                                                                 | Yes                | -ignore_density                                                               |
|                                                                                                                                               |                    | ("Metal density rules")                                                       |
| Minimum enclosed area                                                                                                                         | Yes                | -ignore_enclosed_area                                                         |
| (default and fat metal)                                                                                                                       |                    | ("Basic minimum enclosed area rule and fat table minimum enclosed area rule") |
| Minimum number of                                                                                                                             | Yes                | -ignore_min_edge_length                                                       |
| consecutive short edges                                                                                                                       |                    | ("Minimum number of consecutive short edges rule")                            |

Table 3-9 Design Rules Checked by verify\_drc (Continued)

| Rule                                                                                                   | Checked by default | Command option to enable or disable (Check box in the "DRC Rules" tab in GUI)           |
|--------------------------------------------------------------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------|
| Blockages on metal layers                                                                              | No                 | -check_blockage                                                                         |
|                                                                                                        |                    | ("Blockages on metal layers")                                                           |
| Via size rule                                                                                          | No                 | -check_via_size                                                                         |
|                                                                                                        |                    | ("Via size rule")                                                                       |
| Via spacing (includes minimum                                                                          | Yes                | -ignore_via_spacing                                                                     |
| spacing, the fat contact rule, the fat contact spacing rule, and the fat contact extension range rule) |                    | ("Via spacing rules")                                                                   |
| Maximum number of via stack                                                                            | Yes                | -ignore_stack_level                                                                     |
| layers                                                                                                 |                    | ("Maximum number of stack layer rule")                                                  |
| Stack via rule                                                                                         | Yes                | -ignore_stackable                                                                       |
|                                                                                                        |                    | ("Stack via rule")                                                                      |
| Maximum number of adjacent                                                                             | Yes                | -ignore_adjacent_via                                                                    |
| vias and enclosed via rules                                                                            |                    | ("Maximum number of adjacent via and enclosed via rules")                               |
| Minimum number of fat vias                                                                             | Yes                | -ignore_min_via_number                                                                  |
|                                                                                                        |                    | ("Minimum number of vias defined in the fat contact table (including extension range)") |
| Via array size and spacing                                                                             | No                 | -check_via_farm                                                                         |
| between via arrays                                                                                     |                    | ("Via array size and spacing between two via arrays")                                   |
| Via enclosure rule                                                                                     | No                 | -check_enclosure                                                                        |
|                                                                                                        |                    | ("Via Enclosure rule")                                                                  |
| End-of-line rule                                                                                       | No                 | -check_end_of_line                                                                      |
|                                                                                                        |                    | ("End of line rule")                                                                    |
| Fat poly contact rule                                                                                  | No                 | -check_fat_poly_contact                                                                 |
|                                                                                                        |                    | ("Fat poly contact rule")                                                               |

The Hercules runset file generated by the <code>verify\_drc</code> command is saved in adrc/adrc.ev. You can change the directory to which the runset file is saved by using the <code>-dir</code> option (or the "Hercules runset directory" box in the GUI).

The <code>verify\_drc</code> command creates a Milkyway error view that you can use to report or display the DRC violations. By default, the <code>verify\_drc</code> command saves the generated error view in a file called <code>design\_adrc.err</code>. You can control this name by using the <code>-error\_cell</code> option (or the "Error cell name" box in the GUI). For information about using the error view to debug DRC violations, see "Analyzing DRC Violations" on page 3-47.

## **Using the verify\_route Command**

The <code>verify\_route</code> command checks for routing DRC violations by running an internal design rule checker that checks the design rules defined in the Milkyway technology file. The <code>verify\_route</code> command also checks for open nets.

#### Note:

Unlike the signoff\_drc and verify\_drc commands, which check the design rules for all objects, the verify\_route command checks only objects with a signal routing type. For more information about routing types, see "Setting Routing Types" on page 2-13.

For information about the routing design rules and the technology file attributes that define them, see the *IC Compiler Technology File and Routing Rules Reference Manual*.

By default, the <code>verify\_route</code> command checks and reports the DRC violations and open nets for the entire design. To perform these checks only in a specific region, specify the coordinates of the region by using the <code>-bounding\_box</code> option (or by specifying the coordinates in the "DRC Area" area in the GUI). To prevent checking of the DRC violations, use the <code>-no\_drc</code> option when you run <code>verify\_route</code>. To prevent checking for open nets, use the <code>-no\_opens</code> option when you run <code>verify\_route</code>.

You can reduce the <code>verify\_route</code> runtime by using distributed processing. For information about how to use distributed processing, see "Enabling Distributed Routing" on page 2-18.

You can also use the <code>verify\_route</code> command to check for antenna violations. For more information about checking for and fixing antenna violations, see "Preventing Antenna Problems" on page 4-2.

The <code>verify\_route</code> command can create a Milkyway error view that you can use to report or display the DRC violations. To output a Milkyway error view, use the <code>-output file\_name</code> option when you run the <code>verify\_route</code> command. For information about using the error view to debug DRC violations, see "Analyzing DRC Violations" on page 3-47.

## **Using the Calibre Interface**

You can perform design rule checking with the Calibre tool, convert the Calibre DRC error file to a Milkyway error view, and then report or view the errors in the IC Compiler tool. To convert the Calibre DRC error file to a Milkyway error view, use the read\_drc\_error\_file command (or choose Verification > Read Third-party DRC Error File in the GUI).

For example,

```
icc shell> read drc error file Calibre error file
```

By default, the command saves the generated Milkyway error view in a file called *cell\_name*.err, where *cell\_name* is derived from the Calibre error report. You can specify a name for the Milkyway error view by using the <code>-error cell</code> option.

Note:

The read\_drc\_error\_file command supports only flat Calibre DRC error files; it does not support Calibre hierarchy DRC error files.

You can load the Milkyway error view created by the <code>read\_drc\_error\_file</code> command into the error browser to report or display the DRC violations. For more information about using the error browser, see "Examining Routing and Verification Errors" section in Appendix A of the *IC Compiler Implementation User Guide* and the "Examining Routing and Verification Errors" topic in IC Compiler Help. To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.

## **Analyzing DRC Violations**

After you have generated an error view, either by running one of the Synopsys design rule checking commands or by converting the Calibre results to an error view, you can analyze the DRC violations by

- Using the DRC query commands
- Using the error browser

The following sections describe these capabilities.

# **Using the DRC Query Commands**

You can get information about DRC violations by using the <code>get\_drc\_errors</code> command to create a collection of DRC violations and then using the <code>get\_attribute</code> command to query the attributes of the errors. Some attributes that provide information about DRC errors are <code>type</code>, <code>bbox</code>, <code>nets</code>, and <code>shapes</code>. Note that the availability of attribute values depends on the error type and the verification method used. For a list of all attributes associated with DRC errors, use the <code>list\_attributes -application -class drc\_error</code> command.

By default, the <code>get\_drc\_errors</code> command creates a collection that contains all DRC violations detected during the most recent run of the <code>verify\_route</code> command. You can modify the query by

- Using the -type option to restrict the errors returned by the command to a specific error type. To determine the error type values, use the <code>list\_drc\_error\_types</code> or report\_drc\_error\_type commands.
- Using the -bbox option to restrict the query to a specific region of the design.
- Using the -error\_view option to query a specific error view.

For example, to create a collection that contains all shorted nets detected by the most recent verify\_route run, enter the following command:

```
icc_shell> get_attribute [get_drc_errors -type {Short}] nets
```

To use the DRC query commands on a nondefault error view, such as from a third-party DRC error file, you must first open the error view, either by loading it into the error browser or by using the <code>open\_mw\_cel -not\_as\_current</code> command. For example,

```
icc_shell> read_drc_error_file -error_cell Route_Opt.err error.file
icc_shell> set cellId [open_mw_cel -not_as_current Route_Opt.err]
icc_shell> report_drc_error_type -error_view $cellId
icc_shell> get_drc_errors -error_view Route_Opt.err
```

For more information about these commands, see the man pages.

# **Using the Error Browser**

The error browser lets you examine routing design rule errors in the GUI. You can filter the error list, highlight errors in the layout view, display information about an error on the Query panel, select errors interactively with the Error Selection tool, mark errors as fixed, and save the errors in a file.

For more information about using the error browser, see

- The Error Browser usage help
   To view the Error Browser usage help, choose Help > Error Browser in the error browser window.
- The "Examining Routing and Verification Errors" topic in IC Compiler Help
   To view IC Compiler Help, choose Help > IC Compiler Online Help in the GUI.
- The "Examining Routing and Verification Errors" section in Appendix A of the IC Compiler Implementation User Guide

4

# Using the Classic Router for Design for Manufacturing and Chip Finishing

This chapter describes how to use the classic router for design for manufacturing (DFM) and chip finishing tasks. It contains the following sections:

- Preventing Antenna Problems
- Reducing Critical Areas
- Inserting Redundant Vias
- Inserting Filler Cells
- Inserting Metal Fill
- Performing Notch and Gap Filling
- Lithography Compliance Checking

For information about additional chip finishing tasks, see the *IC Compiler Implementation User Guide*.

# **Preventing Antenna Problems**

In chip manufacturing, gate oxide can be easily damaged by electrostatic discharge. The static charge that is collected on wires during the multilevel metallization process can damage the device or lead to a total chip failure. The phenomena of an electrostatic charge being discharged into the device is referred to as either antenna or charge-collecting antenna problems.

To prevent antenna problems, the IC Compiler tool verifies that for each input pin the metal antenna area divided by the gate area is less than the maximum antenna ratio given by the foundry:

(antenna-area)/(gate-area) < (max-antenna-ratio)

The antenna rules are categorized into basic and advanced rules. For process nodes above 0.18 microns, use the basic antenna rules.

Figure 4-1 shows how to use the IC Compiler tool to perform antenna checking and fixing.

Figure 4-1 IC Compiler Antenna Methodology



## **Setting the Antenna Mode**

The IC Compiler tool supports single-layer, accumulative ratio, accumulative area, and advanced antenna modes.

Using the basic antenna rules, you can select one of the first three antenna modes and decide the area, which can be either surface (polygon) or sidewall, to use for antenna area calculation. Set the doAntennaConx detail route option to select an antenna mode and the useSideWallForAntenna (0 for surface area) detail route option to choose an area:

- Single-layer mode (Set doAntennaConx to 1)
- Accumulative ratio mode (Set doAntennaConx to 2)
- Accumulative area mode (Set doAntennaConx to 3)
- Advanced mode (Set doAntennaConx to 4)

This section discusses only the first three modes using the surface area. For the advanced antenna mode, use the <code>-mode</code> option to decide a mode and follow the advanced antenna rules. For more information, see "Setting the Antenna Mode for the Advanced Antenna Rules" on page 4-9.

Figure 4-2 shows a layout example with a lateral view, which is used to explain antenna modes in Table 4-1: single-layer mode, accumulative ratio mode, and accumulative area mode.

Figure 4-2 Layout Example



Table 4-1 Antenna Modes and Ratios

| Antenna mode                                         | Antenna ratio                                                          |
|------------------------------------------------------|------------------------------------------------------------------------|
| Single-layer mode (ignores all lower-layer segments; | antenna_ratio = connected metal area of the layer / total gate area    |
| allows best routability):                            | M1 ratios                                                              |
|                                                      | Gate1: M1b / Gate1                                                     |
| set_droute_options \                                 | Gate2: M1c / Gate2                                                     |
| -name doAntennaConx \                                | Gate3: M1d / Gate3                                                     |
| -value 1                                             | M2 ratios                                                              |
|                                                      | Gate1: M2b / Gate1                                                     |
|                                                      | Gate2: M2d / Gate2                                                     |
|                                                      | Gate3: M2e / Gate3                                                     |
|                                                      | M3 ratios                                                              |
|                                                      | <ul> <li>Gate1, 2: (M3b + M3c) / (Gate1 + Gate2)</li> </ul>            |
|                                                      | Gate3: M3d / Gate3                                                     |
|                                                      | M4 ratios                                                              |
|                                                      | <ul> <li>Gate1, 2, 3: (M4a + M4b) / (Gate1 + Gate2 + Gate3)</li> </ul> |

Table 4-1 Antenna Modes and Ratios (Continued)

| Antenna mode                                  | Antenna ratio                                                                                                                |
|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| Accumulative ratio mode (includes lower-layer | antenna_ratio = accumulation of ratios for the layer and layers below                                                        |
| segments to the input pins):                  | M1 ratios                                                                                                                    |
|                                               | Gate1: M1b / Gate1                                                                                                           |
| set_droute_options \                          | Gate2: M1c / Gate2                                                                                                           |
| -name doAntennaConx \                         | Gate3: M1d / Gate3                                                                                                           |
| -value 2                                      | M2 ratios                                                                                                                    |
|                                               | Gate1: M1b / Gate1 + M2b / Gate1                                                                                             |
|                                               | Gate2: M1c / Gate2 + M2d / Gate2                                                                                             |
|                                               | Gate3: M1d / Gate3 + M2e / Gate3                                                                                             |
|                                               | M3 ratios                                                                                                                    |
|                                               | <ul> <li>Gate1: M1b / Gate1 + M2b / Gate1 + (M3b + M3c) / (Gate1 + Gate2)</li> </ul>                                         |
|                                               | <ul> <li>Gate2: M1c / Gate2 + M2d / Gate2 + (M3b + M3c) / (Gate1 + Gate2)</li> </ul>                                         |
|                                               | <ul> <li>Gate3: M1d / Gate3 + M2e / Gate3 + M3d / Gate3</li> </ul>                                                           |
|                                               | M4 ratios                                                                                                                    |
|                                               | <ul> <li>Gate1: M1b / Gate1 + M2b / Gate1 + (M3b + M3c) / (Gate1 + Gate2) + (M4a + M4b) / (Gate1 + Gate2 + Gate3)</li> </ul> |
|                                               | <ul> <li>Gate2: M1c / Gate2 + M2d / Gate2 + (M3b + M3c) / (Gate1 + Gate2) + (M4a + M4b) / (Gate1 + Gate2 + Gate3)</li> </ul> |
|                                               | <ul> <li>Gate3: M1d / Gate3 + M2e / Gate3 + M3d / Gate3 + (M4a + M4b)<br/>/ (Gate1 + Gate2 + Gate3)</li> </ul>               |

Table 4-1 Antenna Modes and Ratios (Continued)

| Antenna mode                                     | Antenna ratio                                                                             |
|--------------------------------------------------|-------------------------------------------------------------------------------------------|
| Accumulative area mode (includes all lower-layer | antenna_ratio = all connected metal areas / total gate area                               |
| segments; allows least                           | M1 ratios                                                                                 |
| routability):                                    | Gate1: M1b / Gate1                                                                        |
|                                                  | Gate2: M1c / Gate2                                                                        |
| set_droute_options \                             | Gate3: M1d / Gate3                                                                        |
| -name doAntennaConx \ -value 3                   | M2 ratios • Gate1: (M1b + M2b) / Gate1                                                    |
|                                                  | <ul> <li>Gate2: (M1c + M2d) / Gate2</li> <li>Gate3: (M1d + M2e) / Gate3</li> </ul>        |
|                                                  | M3 ratios                                                                                 |
|                                                  | <ul> <li>Gate1, 2: (M1b + M1c + M2b + M2c + M2d + M3b + M3c) / (Gate1 + Gate2)</li> </ul> |
|                                                  | <ul> <li>Gate3: (M1d + M2e + M3d) / Gate3</li> </ul>                                      |
|                                                  | M4 ratios                                                                                 |
|                                                  | • Gate1, 2, 3: all metal areas / (Gate1 + Gate2 + Gate3)                                  |

# **Defining Antenna Rules**

The IC Compiler tool reads the antenna data that is prepared by the Milkyway Environment tool to fix antenna violations. If a sidewall is used for antenna calculation, you need to define the metal thickness by specifying the unitMinThickness, unitNomThickness, and unitMaxThickness attributes in each layer section of the technology file.

The following three factors influence the computation of antenna rules:

- The antenna mode to identify which metal piece to count
  - Single-layer mode
  - Accumulative ratio mode
  - Accumulative area mode
  - Advanced mode

- The antenna area calculation
  - Surface area = W x L
  - $\circ$  Sidewall area = (W + L) x 2 x thickness
- Protection from diodes and pins

## **Basic Antenna Rules**

The basic antenna rules define the maximum antenna ratio (antenna area to gate area) for metal layers and cut layers.

To use the basic antenna rules, set the <code>doAntennaConx</code> detail route option to 1, 2, or 3, depending on which metal pieces you want to count. For example, to set the antenna mode to single-layer mode, enter

```
icc_shell> set_droute_options -name doAntennaConx -value 1
```

You must also specify whether you want to use surface area or sidewall area. To select the area, set the useSideWallForAntenna detail route option to 0 (the default) for surface area. Set the option to 1 for sidewall area. Note that this option is ignored when doAntennaConx is set to 4 for advanced antenna mode.

After setting the antenna mode and the area, use the following detail route options to define the maximum antenna ratio:

• maxAntennaRatio

This option defines the maximum antenna ratio for metal layers. For example, icc\_shell> set\_droute\_options -name maxAntennaRatio -value 300

• maxCutAntennaRatio

This option defines the maximum antenna ratio for cut layers. For example,

```
icc_shell> set_droute_options -name maxCutAntennaRatio -value 20
```

To get a report on the options that have been set with the set\_droute\_options command, use the report\_droute\_options command as shown in the following example:

```
icc_shell> report_droute_options
```

#### The part of the report showing the antenna settings looks like this:

```
Integer Option for droute doAntennaConx 1
       range [0,4], default=0, stored in cell;
       0: no charge-collecting antenna checking;
;;
       [1-4] check and avoid charge-collecting antenna;
;;
         1: ignore all lower-layer segments, (best routability);
;;
          2: include lower-layer segments to the input pins;
;;
         3: include all lower-layer segments (worst routability).
;;
          4: (advanced mode) use antenna rules defined in libraries
;;
       for a combination of mode 1 - 3 and limited diode protection
;;
Integer Option for droute maxAntennaRatio 300
```

## **Advanced Antenna Rules**

The advanced antenna rules give you more control over defining antenna rules. You can define the rules per layer and specify the diode ratios.

## **Setting the Antenna Mode for the Advanced Antenna Rules**

To use the advanced antenna rules, set the <code>doAntennaConx</code> detail route option to 4 and define the antenna rules by using the <code>define\_antenna\_rule</code> and <code>define\_antenna\_layer\_rule</code> commands. You specify which metal pieces to count during antenna calculation by using the <code>-mode</code> option. Table 4-2 shows the description for each mode.

Table 4-2 Antenna Models Using the -mode Option

| Antenna mode               | Description                                                                   |
|----------------------------|-------------------------------------------------------------------------------|
| Mode 1: Single-layer       | Uses surface area and ignores all lower-layer segments.                       |
| Mode 2: Accumulative ratio | Uses surface area which includes all lower-layer segments to the input pins.  |
| Mode 3: Accumulative area  | Uses surface area which includes all lower-layer segments.                    |
| Mode 4: Single-layer       | Uses sidewall area and ignores all lower-layer segments.                      |
| Mode 5: Accumulative ratio | Uses sidewall area which includes all lower-layer segments to the input pins. |
| Mode 6: Accumulative area  | Uses sidewall area which includes all lower-layer segments.                   |

For example, to set the advanced antenna mode and to use the advanced antenna rules, enter the following commands:

```
icc_shell> set_droute_options -name doAntennexConx -value 4
icc_shell> define_antenna_rule mw_lib -mode mode \
    -diode_mode diode_mode \
    -metal_ratio metal_ratio \
    -cut_ratio cut_ratio \
    [-protected_metal_scale metal_scale] \
    [-protected_cut_scale cut_scale]

icc_shell> define_antenna_layer_rule mw_lib -mode mode \
    -layer layer_name \
    -ratio ratio \
    [-pratio pratio] \
    [-nratio nratio] \
    -diode_ratio {v0 v1 v2 v3 [v4]} \
    [-scale_factor scale_factor]
```

#### **Setting the Diode Mode**

Antenna ratio calculation with diode protection is based on the vector  $\{v0\ v1\ v2\ v3\ [v4]\}\{s0\ s1\ s2\ s3\ s4\ s5\}$  that you specify by using the <code>-diode\_ratio</code> option of the <code>define\_antenna\_layer\_rule</code> command. The vector defines the maximum allowable antenna ratio (max-antenna-ratio) of the antenna area to the gate area if the antenna is protected by diodes. The antenna ratio of each metal layer must be less than the allowable max-antenna-ratio (antenna-area / gate-area < max-antenna-ratio).

The default value of the vector  $\{v0\ v1\ v2\ v3\ [v4]\}$  is  $\{0\ 0\ 1\ 0\ 0\}$  and can be written as  $\{v0\ v1\ v2\ v3\} = \{0\ 0\ 1\ 0\}$  without the upper limit diode protection v4. Both vectors,  $\{0\ 0\ 1\ 0\ 0\}$  and  $\{0\ 0\ 1\ 0\}$ , indicate that the upper limit of the diode protection is 0.

The value of diode protection, dp, is recorded on each output pin of a cell. If the value of the diode protection of an output pin is dp, the antenna ratio is calculated as follows:

- For diode modes 0 to 4, use vector {v0 v1 v2 v3} to calculate the allowable max-antenna-ratio.
- For diode modes 5 to 8, use vector {v0 v1 v2 v3} to calculate the antenna ratio.
- For diode modes 9 and 10, use vector {v0 v1 v2 v3 v4} to calculate the allowable max-antenna-ratio.
- For diode modes 11 and 12, use both vectors {v0 v1 v2 v3 v4} and {s0 s1 s2 s3 s4 s5} to calculate the allowable max-antenna ratio.

Note that vector (s0 s1 s2 s3 s4 s5) is used for diode modes 11 and 12 only.

Table 4-3 shows how to calculate the antenna ratio for each diode mode.

Table 4-3 Antenna Ratio Calculation Based on Diode Mode

| Diode mode         | Allowable ratio calculation                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Diode modes 2 to 4 | <ul> <li>allowable max-antenna-ratio</li> <li>When dp &gt; 0,     - if v4 &lt;&gt; 0, the allowable max-antenna-ratio = min (((dp + v1) * v2 + v3), v4)     - If v4 == 0, the allowable max-antenna-ratio = (dp + v1) * v2 + v3</li> <li>When dp &lt;= v0, the allowable max-antenna-ratio = layerMaxRatio</li> </ul>                                                                               |
| Diode mode 5       | <ul> <li>antenna_ratio = metal_area / (gate_area + equi_gate_area)</li> <li>If max_diode_protection &lt;= v0, equi_gate_area = 0</li> <li>Else if (v4 &lt;&gt; 0), equi_gate_area = min (((max_diode_protection + v1) * v2 + v3), v4)</li> <li>Else equi_gate_area = (max_diode_protection + v1) * v2 + v3</li> </ul>                                                                               |
| Diode mode 6       | <ul> <li>antenna_ratio = metal_area / (gate_area + equi_gate_area)</li> <li>If total_diode_protection &lt;= v0, equi_gate_area = 0</li> <li>Else if (v4 &lt;&gt; 0), equi_gate_area = min (((total_diode_protection + v1) * v2 + v3), v4)</li> <li>Else equi_gate_area = (total_diode_protection + v1) * v2 + v3</li> </ul>                                                                         |
| Diode mode 7       | <ul> <li>antenna_ratio = (metal_area - equi_metal_area) / gate_area</li> <li>if max_diode_protection &lt;= v0, equi_metal_area = 0</li> <li>Else if (v4 &lt;&gt; 0), equi_metal_area = min (((max_diode_protection + v1) * v2 + v3), v4)</li> <li>Else equi_metal_area = (max_diode_protection + v1) * v2 + v3</li> <li>if equi_metal_area &gt; metal_area, equi_metal_area = metal_area</li> </ul> |

Table 4-3 Antenna Ratio Calculation Based on Diode Mode (Continued)

| Diode mode    | Allowable ratio calculation                                                                                        |
|---------------|--------------------------------------------------------------------------------------------------------------------|
| Diode mode 8  | antenna_ratio = (metal_area - equi_metal_area) / gate_area                                                         |
|               | <ul> <li>If total_diode_protection &lt;= v0, equi_metal_area = 0</li> </ul>                                        |
|               | <ul> <li>Else if (v4 &lt;&gt; 0), equi_metal_area = min (((total_diode_protection + v1) * v2 + v3), v4)</li> </ul> |
|               | <ul> <li>Else equi_metal_area = (total_diode_protection + v1) * v2 + v3</li> </ul>                                 |
|               | <ul> <li>If equi_metal_area &gt; metal_area, equi_metal_area = metal_area</li> </ul>                               |
| Diode mode 9  | antenna_ratio = scale * metal_area / gate_area                                                                     |
|               | <ul> <li>If max_diode_protection &lt;= v0, scale = 1.0</li> </ul>                                                  |
|               | <ul> <li>Else scale = max (1 / ((max_diode_protection + v1) * v2 + v3), v4)</li> </ul>                             |
| Diode mode 10 | antenna_ratio = scale * metal_area / gate_area                                                                     |
|               | <ul> <li>If total_diode_protection &lt;= v0, scale = 1.0</li> </ul>                                                |
|               | <ul> <li>Else scale = max (1 / ((total_diode_protection + v1) * v2 + v3), v4)</li> </ul>                           |
| Diode mode 11 | antenna_ratio = scale * metal_area / gate_area                                                                     |
|               | <ul> <li>If max_diode_protection &lt; v0, scale = s0</li> </ul>                                                    |
|               | <ul> <li>If max_diode_protection &lt; v1, scale = s1</li> </ul>                                                    |
|               | <ul> <li>If max_diode_protection &lt; v2, scale = s2</li> </ul>                                                    |
|               | <ul> <li>If max_diode_protection &lt; v3, scale = s3</li> </ul>                                                    |
|               | <ul> <li>If max_diode_protection &lt; v4, scale = s4</li> </ul>                                                    |
|               | <ul> <li>If max_diode_protection &gt;= v4, scale = s5</li> </ul>                                                   |

Table 4-3 Antenna Ratio Calculation Based on Diode Mode (Continued)

| Diode mode    | Allowable ratio calculation                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Diode mode 12 | <ul> <li>antenna_ratio = scale * metal_area / gate_area</li> <li>If total_diode_protection &lt; v0, scale = s0</li> <li>If total_diode_protection &lt; v1, scale = s1</li> <li>If total_diode_protection &lt; v2, scale = s2</li> <li>If total_diode_protection &lt; v3, scale = s3</li> <li>If total_diode_protection &lt; v4, scale = s4</li> <li>If total_diode_protection &gt;= v4, scale = s5</li> </ul> |

## Example for Diode Modes 2, 3 and 4

The vector {v0 v1 v2 v3} is {0.7 0.0 200 2000}, three diodes are connected to a single net, and the value layerMaxRatio is 400.

```
Diode A: diode protection=0.5, allowable ratio is 400 if protected Diode B: diode protection=1.0, allowable ratio is 2200 if protected Diode C: diode protection=1.5, allowable ratio is 2200 if protected The antenna_ratio calculation of a route net:

Diode mode 2: allowable ratio = 2300 (maximum value)

Diode mode 3: allowable ratio = 400+2200+2300 = 4900

Diode mode 4: allowable ratio = ((0.5+1.0+1.5)*200)+2000 = 2600
```

#### **Example for Diode Modes 5 and 6**

The vector {v0 v1 v2 v3} is {0.0 0 1 0}, three diodes are connected to a single net, and the value of layerMaxRatio is 400.

#### **Example for Diode Modes 7 and 8**

The vector {v0 v1 v2 v3} is {0.7 0.0 150 800}, three diodes are connected to a single net, and the value of layerMaxRatio is 400.

```
Diode A: diode protection = 0.5

Diode B: diode protection = 1.0

Diode C: diode protection = 1.5

Total diode protection = 0.5+1.0+1.5 = 3.0

The antenna_ratio calculation of a route net:

Diode mode 7: (Use maximum dp to compute equi_metal_area)

antenna_ratio = (metal_area - equi_metal_area)/gate_area

= (metal_area - ((1.5+0)*150+800))/gate_area

= (metal_area - 1025)/gate_area

Diode mode 8: (Use total dp to compute equi_metal_area)

antenna_ratio = (metal_area - equi_metal_area)/gate_area

= (metal_area - ((3.0+0)*150+800))/gate_area

= (metal_area - 1250)/gate_area
```

#### The following shows an example of the advanced antenna rules:

```
set lib [current mw lib]
remove_antenna_rules $lib
define_antenna_rule $lib -mode 1 -diode_mode 4 -metal_ratio 300 \
   -cut ratio 20
define_antenna_layer_rule $lib -mode 1 -layer "M1" -ratio 300 \
   -diode_ratio {0.09 0 123 16880}
define_antenna_layer_rule $1ib -mode 1 -layer "M2" -ratio 300 \
   -diode_ratio {0.09 0 123 16880}
define_antenna_layer_rule $lib -mode 1 -layer "M3" -ratio 300 \
   -diode ratio {0.09 0 123 16880}
define_antenna_layer_rule $lib -mode 1 -layer "M4" -ratio 300 \
   -diode_ratio {0.09 0 123 16880}
define_antenna_layer_rule $1ib -mode 1 -layer "M5" -ratio 400 \
   -diode_ratio {0.09 0 123 20000}
define_antenna_layer_rule $lib -mode 1 -layer "VIA1" -ratio 20 \
   -diode ratio {0.09 0 110 500}
define_antenna_layer_rule $lib -mode 1 -layer "VIA2" -ratio 20 \
   -diode_ratio {0.09 0 110 500}
define_antenna_layer_rule $lib -mode 1 -layer "VIA3" -ratio 20 \
   -diode_ratio {0.09 0 110 500}
define_antenna_layer_rule $lib -mode 1 -layer "VIA4" -ratio 20 \
   -diode ratio {0.09 0 110 500}
```

## **Reporting Antenna Rules**

You can get a report of antenna rules by using the report\_antenna\_rules command. For example,

icc\_shell> report\_antenna\_rules -output ./antenna.rule design

## **Removing Antenna Rules**

You can remove the antenna rules you set by using the <code>remove\_antenna\_rules</code> command. For example,

icc\_shell> remove\_antenna\_rules design

# **Checking Antenna Rules**

After the antenna modes and rules are defined, you can proceed with antenna rules checking. The design rule checker of the detail router checks antenna rules automatically. Every routing command checks and reports the number of antenna violations as follows:

```
@@@@ Total nets not meeting constraints = 116
```

where the number represents the number of nets with antenna violations.

To get a detailed report of antenna violations, you can use <code>verify\_route -antenna</code> or the <code>report\_antenna\_ratio</code> command. Alternatively, you can choose Route > Verify Route or Route > Report Antenna Ratio in the GUI to get an antenna violation report.

#### Note:

You can set the topAntennaFixRange and maxAntennaPinCount detail route options to speed up the runtime of antenna checking and fixing.

# **Specifying Antenna Properties**

You can set external antenna properties for all I/O ports or for a specified I/O port by using the define\_io\_gate\_size, define\_io\_diode\_protection, and define\_io\_antenna\_area commands. To remove the definitions set by these commands, use the remove\_io\_antenna\_properties command.

You can report the antenna properties set by these commands by using the report io antenna properties command.

## **Fixing Antenna Violations**

You can fix antenna violations either before or after running the <code>route\_opt</code> command. If both antenna fixing and routing optimization are needed, running the <code>route\_opt</code> command first can shorten the overall turnaround time. However, running the <code>route\_opt</code> command after antenna fixing can generate a good layout initially. Note that you need to remove as many DRC violations as possible before the antenna fixing step. When DRC violations have been eliminated, you can fix the antenna violations by running search and repair and inserting diodes. Before performing these tasks, ensure that the antenna mode is set and that the antenna rules are defined as described in the previous sections.

## **Running Search and Repair**

After antenna checking and fixing, run search and repair to fix antenna violations. For example,

```
icc_shell> route_search_repair -loop 20 -rerun_drc
```

Search and repair performs two types of metal-jog operations for antenna fixing. Both approaches decrease the antenna ratio by splitting a large metal polygon into several upper-level polygons.

- Break the antenna with a higher-level metal segment.
  - Use this technique to fix most antenna violations. For antenna violations happening at metal-N, inserting a small segment of metal-(N+1) close to the gate reduces the ratio between the remaining metal-N, making the ratio much lower. This approach is not suitable for fixing top-metal layer antennas when the output pin can provide only limited protection because there is no way for the router to break antenna violations at the topmost metal layer.
- Move down to a lower-level metal.
  - Use this technique to fix only the topmost layer antenna violations when output pins provide only limited protection. For antenna violations happening at metal-N, replace part of the metal-N with metal-(N-1 or lower) to reduce the ratio. However, splitting the metal layer into many pieces might have a negative impact on RC and timing delay.

Fore more information about search and repair, see "Search and Repair" on page 3-26.

## **Inserting Diodes**

One way to protect gates from antenna effects is to provide a discharge path for the accumulated charge to leave the net. However, the discharge path should not allow current to flow during normal chip operation. Discharging can be accomplished by inserting a reverse-biased diode on the net close to the gate that is being protected.

Based on the results of the antenna checking, the tool inserts a diode cell or multiple diodes when the antenna ratio requires the protection of more than one diode for each violation.

The diode port of the diode cell must be defined as such in the library. In the Milkyway environment, you can use the <code>write\_def</code> command to define diode pins. For details, see the Library Data Preparation for IC Compiler User Guide. In addition, the diode protection value must be defined in the physical library. For details, see the description of the <code>antenna\_diffusion\_area</code> attribute in the Library Compiler Physical Libraries User Guide and the Library Compiler Physical Libraries Reference Manual.

To minimize the impact on the existing placement and routing, you can choose to freeze the existing cell placement and the routing so that the diode cells can be placed in existing empty spaces only. You can also choose to complete the routing of the diode cells during the insertion process when the cell placement is already frozen. Whenever possible, the tool ties the diode cells to the existing wires without ripping up and rerouting the entire net.

The tool considers voltage areas when inserting diode cells and also observes the logic hierarchy assignments for diode cells.

To fix antenna violations, use the <code>insert\_diode</code> command or choose Finishing > Insert Diode in the GUI. For example,

icc\_shell> insert\_diode -signal\_route\_options advanced

By default, the <code>insert\_diode</code> command triggers the internal antenna checker to identify the antenna violations and then inserts one or multiple diode cells for each violation. For diode modes 2, 5, and 7, the <code>insert\_diode</code> command inserts only one diode cell to fix an antenna violation. For diode modes 3, 4, 6, and 8, the <code>insert\_diode</code> command inserts multiple diodes as needed to fix an antenna violation.

#### The command syntax is

```
insert_diode
  [-nets collection_of_nets]
  [-antenna_check_engine internal | hercules]
  [-internal_check_option all | top_layer_only]
  [-no_auto_cell_selection]
  [-diode_cells collection_of_diode_cells]
  [-prefix prefix_name]
  [-use_hierarchical_diode_instance_name]
  [-same_row]
  [[-dont_freeze_existing_placement] |
    [-routing skip | when_all_violations_are_gone | always]]
  [-signal_route_options ignore_lower_layers | include_lower_layers|
    include_all_lower_layers | advanced]
  [-max_ratio max_ratio_number]
```

By default, all nets are checked for antenna violations. To restrict checking to a list of nets, use the <code>-nets</code> option. By default, the tool uses its own internal antenna checker. To use the external Hercules check instead, specify <code>-antenna\_check\_engine hercules</code>. To report only top-level antenna violations rather than all violations, specify

```
-internal_check_option top_layer_only.
```

By default, any diode cells can be used for fixing. To specify which diode cells to use, specify the  $-no\_auto\_cell\_selection$  option together with the  $-diode\_cells$  option. To attempt diode insertion in the same row as the violation, use the  $-same\_row$  option; by default, there is no preferred row for insertion.

By default, diode insertion does not disturb existing standard cells. To allow existing cells to be moved to make room for inserted diodes, use the <code>-dont\_freeze\_existing\_placement</code> option. The <code>-routing</code> option lets you specify whether to perform routing: <code>always</code>, <code>when\_all\_violations\_are\_gone</code>, Or <code>skip</code>.

Use the <code>-signal\_route\_options</code> to specify the rules used for antenna checking: <code>ignore\_lower\_layers</code>, <code>include\_lower\_layers</code>, <code>include\_all\_lower\_layers</code>, <code>or</code> advanced. The <code>-max\_ratio</code> option specifies the maximum allowable ratio of wiring area to gate area to be used for antenna checking, overriding the default antenna checking rules.

For more information about the command options, see the man page for the <code>insert\_diode</code> command.

To remove diodes, use the remove\_diode command or choose Finishing > Remove Diodes in the GUI. The remove\_diode command first disconnects all the diode ports on all the nets specified; then it removes the diode cells that are fully disconnected. For example,

```
icc_shell> remove_diode -nets net_name
icc_shell> remove_diode -nets [get_nets -hierarchical net_name]
```

## **Connecting Spare Diodes**

Instead of inserting new diodes to fix antenna violations, you can insert spare diodes at the same time as standard cell placement and then connect the spare diodes as needed when antenna violations are found. The unused spare diodes are left unconnected. This technique lets you fix antenna violations without disturbing the placement of existing standard cells. However, you must allocate some placement area to accommodate the spare diodes. Adding more spare diodes uses more area resources but makes antenna fixing easier because a nearby spare diode is more likely to be available where needed.

The diode port of the diode cell must be defined as such in the library. In the Milkyway environment, you can use the <code>write\_def</code> command to define diode pins. For details, see the Library Data Preparation for IC Compiler User Guide. In addition, the diode protection value must be defined in the physical library. For details, see the description of the <code>antenna\_diffusion\_area</code> attribute in the Library Compiler Physical Libraries User Guide and the Library Compiler Physical Libraries Reference Manual.

To take advantage of spare diodes for antenna violation fixing, you need to add the spare diodes either before or after standard cell placement and before routing the areas where antenna violations might occur. For details, see the "ECO Flow" chapter in the *IC Compiler Implementation User Guide*.

To fix antenna violations by connecting spare diodes, use the <code>connect\_spare\_diode</code> command or choose Finishing > Connect Spare Diode in the GUI. For example,

```
icc_shell> connect_spare_diode
```

The connect\_spare\_diode command checks for antenna violations and fixes those violations by connecting the problem nets to nearby spare diodes.

#### The command syntax is

```
connect_spare_diode
  [-exclude_nets collection_of_nets]
  [-antenna_check_engine internal | hercules]
  [-internal_check_option all | top_layer_only]
  [-routing skip | route]
  [-distance distance_number]
  [-signal_route_options ignore_lower_layers |
    include_lower_layers | include_all_lower_layers | advanced]
  [-max ratio max ratio number]
```

The -antenna\_check\_engine option specifies which antenna checking engine to use, either the IC Compiler internal antenna checker (internal, the default) or the external Hercules antenna checker (hercules). If the internal checker is being used, the -internal\_check\_option option specifies whether to report all antenna violations (all) or only the top-layer violations (top\_layer\_only).

The -distance option specifies the maximum distance from the problem net that is searched for a spare diode. If no spare diode can be found within this distance, the

command reports an error. You specify the distance as an integer multiple of the global routing cell size. The default is 10, which means that spare diode cells should be made available within 10 global routing cell lengths of anywhere an antenna violation might occur. For example, an array of spare diode cells with a spacing of 14 global routing cell lengths might be sufficient.

The <code>-exclude\_nets</code> option specifies a collection of nets that should not be connected to diodes. If you do not set this option, all nets are connected to diodes.

The connect\_spare\_diode command finds each antenna violation, identifies one or more nearby spare diodes required for fixing, and sets the net ID of the diode pins to the name of the problem net that must be connected. The number of diodes required to fix a particular antenna violation depends on the antenna checking method. By default, the command also invokes the detail router in ECO mode to perform the required routing between the problem net and the diode. However, if you use the <code>-routing skip</code> option, the routing step is skipped. In that case, you can perform the necessary routing separately at a later time. Detail routing should be complete before you attempt to connect the spare diodes.

By default, the <code>connect\_spare\_diode</code> command uses the antenna-checking mode specified by the <code>doAntennaConx</code> detail route option, as explained in "Defining Antenna Rules" on page 4-7. You can override the <code>set\_droute\_options</code> setting by using the <code>-signal\_route\_options</code> option with the <code>connect\_spare\_diode</code> command. The four possible override settings are <code>ignore\_lower\_layers</code>, <code>include\_lower\_layers</code>, <code>include\_all\_lower\_layers</code>, and <code>advanced</code>. These settings correspond to the <code>doAntennaConx</code> antenna mode settings of 1, 2, 3, and 4, respectively. The <code>doAntennaConx</code> antenna mode must be set to 1, 2, 3, or 4 (not 0) or the <code>-signal\_route\_options</code> option must be used with the <code>connect\_spare\_diode</code> command, even if the external Hercules antenna checker is being used.

By default, for antenna mode settings of 1, 2, or 3, the <code>connect\_spare\_diode</code> command checks for an antenna-to-gate area ratio that exceeds the <code>maxAntennaRatio</code> option of the <code>set\_droute\_options</code> command, as explained in "Defining Antenna Rules" on page 4-7. You can override the <code>set\_droute\_options</code> setting by using the <code>-max\_ratio</code> option with the <code>connect\_spare\_diode</code> command.

You can also perform the functions of the <code>connect\_spare\_diode</code> command in the GUI by choosing Finishing > Connect Spare Diode.

## **Setting Detail Route Options to Control Antenna Fixing**

You can set the detail route options listed in Table 4-4 to fix antenna violations by using the set\_droute\_options command. The option settings are stored with the cell.

Table 4-4 Detail Route Options

| Option                | Range          | Default | Description                                                                                                                |
|-----------------------|----------------|---------|----------------------------------------------------------------------------------------------------------------------------|
| useSideWallForAntenna | [0, 1]         | 0       | 0: Uses the wire area to compute antenna ratio.                                                                            |
|                       |                |         | 1: Uses the wire sidewall area to compute antenna ratio.                                                                   |
|                       |                |         | You need to specify the thickness in the technology file. This option is ignored when doAntennaConx is set to 4.           |
| maxCutAntennaRatio    | [0, 1000000]   | 0       | 0: Does not compute cut area.                                                                                              |
|                       |                |         | N: The ratio of the total area of the charge-collecting antenna cuts to the total gate size should not exceed the value N. |
|                       |                |         | This option is ignored when doAntennaConx is set to 4.                                                                     |
| maxAntennaRatio       | [0, 1000000]   | 1000000 | N: The ratio of the total area of the charge-collecting antenna to the total gate size should not exceed the value N.      |
|                       |                |         | This option is ignored when doAntennaConx is set to 4.                                                                     |
| maxAntennaPinCount    | [-1, 1000000]  | -1      | -1: Checks antenna on all nets.                                                                                            |
|                       |                |         | N: Skips checking antenna on nets with more than N pins.                                                                   |
| minAntennaRatioScale  | [0.000, 1.000] | 0.000   | N: Shows the minimal antenna ratio scale for diode modes 11 and 12.                                                        |
| maxAntennaRatioScale  | [0.000, 1.000] | 1.000   | N: Shows the maximal antenna ratio scale for diode modes 11 and 12.                                                        |

Table 4-4 Detail Route Options (Continued)

| Option                      | Range                   | Default | Description                                                                                                                                                                    |
|-----------------------------|-------------------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| topAntennaFixRange          | [-1, 10]                | -1      | -1: Fixes all top-layer antenna violations by pushing wires down.                                                                                                              |
|                             |                         |         | N: Fixes only top-layer antenna violations if the ratio is less than [safeRatio x (1 + 0.1 * N)] to avoid pushing too many wires to lower layers.                              |
|                             |                         |         | This option is valid only when doAntennaConx is set to 4. (Note: When topAntennaFixRange is set, the log file also shows the number of nets that are not fixed by the router.) |
| dontMergeGateForAntenna     | [0, 1]                  | 0       | When 2 or more input gates are connected,                                                                                                                                      |
|                             |                         |         | 0: The router adds their areas together to compute antenna ratio.                                                                                                              |
|                             |                         |         | 1: The router does not add the area of connected input gates.                                                                                                                  |
| outputPinDischarge          | [0, 1]                  | 1       | Assumes that no output pin can discharge static electricity.                                                                                                                   |
|                             |                         |         | 1: Assumes that output pins discharge static electricity.                                                                                                                      |
|                             |                         |         | This option is ignored when doAntennaConx is set to 4.                                                                                                                         |
| defaultTopPinExtAntennaArea | [0.000,<br>1000000.000] | 0.000   | N: Sets the default extAntennaArea value at all metal layers for top-cell pins. This option replaces breakAntennaToTopPin.                                                     |
| defaultTopPinExtGateSize    | [0.000,<br>1000000.000] | 0.000   | N: Sets the default ${\tt extGateSize}$ value for top-cell pins.                                                                                                               |

Table 4-4 Detail Route Options (Continued)

| Option               | Range  | Default | Description                                                                                                                     |
|----------------------|--------|---------|---------------------------------------------------------------------------------------------------------------------------------|
| breakAntennaToTopPin | [0, 2] | 0       | 0: Treats top-level pins as floating.                                                                                           |
|                      |        |         | 1: Treats top-level pins as they are connected to a huge antenna and breaks the antenna (Requires a jumper at top metal layer). |
|                      |        |         | 2: Connects all input pins to top-level pins only through the highest routing layer of the net.                                 |
| checkAntennaOnPG     | [0, 1] | 0       | 0: Does not check antenna on power and ground nets.                                                                             |
|                      |        |         | 1: Checks antenna on power and ground nets.                                                                                     |

## **Reducing Critical Areas**

A critical area is a region of the design where, if the center of a random particle defect falls there, the defect causes circuit failure, thereby reducing yield. A conductive defect causes a short fault, and a nonconductive defect causes an open fault.

The following sections describe how to

- Report critical areas
- Display critical area maps
- Reduce critical area short faults by performing wire spreading
- Reduce critical area open faults by performing wire widening

## **Reporting Critical Areas**

After routing is complete, you can report layout-critical areas that are susceptible to random particle defects, which cause shorts and opens during the fabrication process.

The results from the critical area analysis report are output to an output\_heatmap text file. You can see the critical area results graphically by displaying critical area heat maps.

To report critical areas, use the report\_critical\_area command (or choose Finishing > Report Critical Area Map in the GUI).

Table 4-5 describes the report\_critical\_area options. For more information, see the man page.

Table 4-5 report\_critical\_area Command Options

| Command option                                                                              | Description                                                                                                    |
|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| -fault_type short   open                                                                    | Specifies the type of fault to check for.                                                                      |
| ("Fault type" radio buttons in the GUI)                                                     | The default is short.                                                                                          |
| <pre>-particle_distr_func_file file_name</pre>                                              | The name of the input file that contains the particle distribution function to be used during the calculation. |
| ("Particle distribution function file" box in the GUI)                                      | By default, the tool uses an internal particle probability function.                                           |
| -suppress_zeros_in_report                                                                   | Prevents reporting of zero results.                                                                            |
| ("Suppress zeros in report" check box in the GUI)                                           | By default, all results are reported.                                                                          |
| -multiparticle_report_format true   false                                                   | Outputs a report containing the critical area analysis result of each individual particle size.                |
| ("Multi particle report format" check box in the GUI)                                       | By default, the tool outputs normalized results.                                                               |
| <pre>-tsmc_encr_particle_distr_file ("TSMC encrypted format" check box in the GUI)</pre>    | Specifies that the particle distribution function file is in TSMC encrypted format.                            |
| <pre>-layer_alias_DSD_format {X Y Z T R} ("Metal scheme directives" boxes in the GUI)</pre> | Specifies the layer alias used for defect size distribution (DSD) of each layer.                               |
| -input_layers layers ("Input layer" list in the GUI)                                        | Specifies the metal layers for which the critical area is calculated.                                          |
|                                                                                             | By default, the critical area is calculated for all metal layers.                                              |

Often the particle probability function is considered sensitive data. When security for a sensitive particle distribution file from a foundry is of concern, use the process\_particle\_probability\_file command, which provides a way to encrypt and decrypt the particle probability function. Critical area analysis can work with such an encrypted particle probability function.

A secret key is used to encrypt the particle probability function. The encrypted file cannot be decrypted without the key. To encrypt and decrypt a particle probability function file, use the process\_particle\_probability\_file command.

#### The command syntax is

```
process_particle_probability_file
   -key string
   -input_file file_name
   -output_file file_name
```

Critical area analysis takes the encrypted file as its input and processes it without the key. The output is the heat map based on the encrypted particle probability function; it is in text format. The text format of the particle probability function is still accepted as input to critical area analysis. If an encrypted file is given as input, the file is internally decrypted and used.

## **Displaying Critical Area Maps**

Critical area maps provide an indication of places where a chip might fail due to particle defects, which can cause shorts and opens.

To display a critical area for the current design,

- 1. Specify the type of defect to display by choosing one of the following:
  - Finishing > Open Critical Area Map
  - Finishing > Short Critical Area Map

The Map Mode panel appears.

- 2. Select a metal layer for which critical area shorts or opens are to be displayed.
- 3. Modify the critical heat ranges by changing or removing the maximum or minimum threshold values.
- 4. Adjust other display parameters. You can make text visible in the map.
- 5. Click Apply.

To update the critical area map data after you perform wire spreading, click Reload. This action opens the (Re)Calculate Open Critical Area Map Data dialog box, from which you can run the report\_critical\_area -fault\_type short command.

To update the critical area map data after you perform wire widening, click Reload. This action opens the (Re)Calculate Open Critical Area Map Data dialog box, from which you can run the report\_critical\_area -fault\_type open command.

For more information about using critical area maps, see the "Examining Critical Area Maps" topic in IC Compiler Help.

## **Performing Wire Spreading**

After you have performed detail routing, you can perform wire spreading to increase the average spacing between wires, which reduces the critical area short faults and therefore improves yield.

To perform wire spreading, use the route\_spreadwires command (or choose Finishing > Route Spread Wires in the GUI).

The route\_spreadwires command can make the following changes to the layout:

- Move wires on the same layer to widen the spaces between wires
- Move wires to the upper or lower metal layers as needed to resolve DRC violations caused by widening spaces

When spreading wires, a piece of the original wire is broken and pushed away, and jog wires are created at both ends to maintain a connection. By default, the minimum ratio of the jog length to the layer pitch is two. You can modify this minimum ratio by using the <code>-min\_jog\_length</code> option. After spreading, the <code>route\_spreadwires</code> command performs search and repair to fix any DRC violations caused as a result of spreading. By default, the classic router performs 10 search-and-repair loops. You can control the number of loops by using the <code>-search\_repair\_loop</code> option. You can reduce the turnaround time for running the search-and-repair loops by using distributed routing. To use distributed routing, specify the number of CPUs by using the <code>-num\_cpus</code> option. For information about setting up for distributed routing, see "Enabling Distributed Routing" on page 2-18.

Because any change to the routing pattern can affect the timing, the tool provides timing-driven wire spreading to minimize the timing impact. You enable timing-driven wire spreading by using the <code>-timing\_driven</code> and <code>-setup\_slack\_threshold</code> options. When you specify these options, the command finds the timing-critical nets and prevents spreading from being performed on them. Timing-critical nets are those nets that have a slack less than the specified threshold value.

In most cases, timing is improved, due to the wider net spacing produced by wire spreading. However, having too many timing-violated nets in the design can have a negative impact on the final critical area improvement. Often, when too many nets have violations, the cause is that only a limited number of segments can be moved during spreading. To allow more nets to be spread, set the setup slack threshold option to a negative value. For example, if this option is set to -0.5, the router spreads all nets that have slack greater than -0.5. The default is 0.0.

For example, to perform timing-driven wire spreading followed by six search-and-repair loops, enter the following command:

```
icc_shell> route_spreadwires -search_repair_loop 6 \
   -timing_driven -setup_slack_threshold 0.15
```

## **Performing Wire Widening**

After you have performed detail routing and wire spreading, you can perform wire widening to increase the average width of the wires, which reduces the critical area open faults and therefore improves yield.

To perform wire widening, use the route\_widen\_wire command (or choose Finishing > Route Widen Wires in the GUI).

The route\_widen\_wire command widens all wires in the design to 1.5 times their original width and then performs search and repair to fix any DRC violations caused as a result of widening. By default, the classic router performs 10 search-and-repair loops. You can control the number of loops by using the -search\_repair\_loop option.

#### Note:

The widened wires do not trigger fat wire spacing rules.

When you widen the wires, it changes the timing of your design. Wire widening has a timing-driven mode that allows you to perform wire widening with minimal impact on the design timing.

Use the <code>-timing\_driven</code>, <code>-setup\_slack\_threshold</code>, and <code>-hold\_slack\_threshold</code> options to consider timing during wire widening. In that case, the command finds the timing-critical nets and prevents widening from being performed on them. Timing-critical nets are those nets that have a slack less than the specified threshold value.

For example, to perform wire widening followed by 20 search-and-repair loops, enter the following command:

icc\_shell> route\_widen\_wire -search\_repair\_loop 20

## **Inserting Redundant Vias**

After routing and postrouting optimization, you can replace single-cut vias with multiple-cut via arrays (a process sometimes called via doubling) or with a different via with the same layers. The via is replaced only if the via array or the new via does not introduce DRC violations.

To insert redundant vias, use the insert\_redundant\_vias command (or choose Finishing > Insert Redundant Vias).

#### The command syntax is

```
insert_redundant_vias
  -from_via list_of_from_vias
  -to_via list_of_to_vias
  [-to_via_x_size list_of_x-sizes]
  [-to_via_y_size list_of_y-sizes]
  [-via_array_no_swap]
  [-optimize_level level_of_optimization]
  [-num_cpus number_of_cpus]
  [-auto_mode preview | insert]
```

There are two redundant via insertion methods: manual and automatic.

The manual method uses the <code>-from\_via</code>, <code>-to\_via</code>, <code>-to\_via\_x\_size</code>, and <code>-to\_via\_y\_size</code> options to customize the insertion process by specifying which kinds of redundant vias are inserted and the allowed array dimensions. For example, the following command replaces all VIA23 single-cut vias with 1x3 VIA23 arrays and all VIA34 single-cut vias with 5x1 VIA34 arrays:

```
icc_shell> insert_redundant_vias \
  -from_via {VIA23 VIA34} -to_via {VIA23 VIA34} \
  -to_via_x_size {1 5} -to_via_y_size {3 1}
```

The automatic method uses the <code>-auto\_mode</code> option. If you use the <code>-auto\_mode</code> insert option, the command inserts the default vias defined in the technology file as redundant vias for all layers. For example,

```
icc_shell> insert_redundant_vias -auto_mode insert
```

If you use the <code>-auto\_mode preview</code> option, the command lists all of the vias on all the layers without referencing the technology file. You can then cut and paste part or all of the listed vias into a new manual-method command that specifies the <code>-to\_via</code> and <code>-from\_via</code> options.

The Insert Redundant Vias dialog box in the GUI (Finishing > Insert Redundant Vias) is very helpful in setting the options for the <code>insert\_redundant\_vias</code> command.

## **Inserting Filler Cells**

Filler cells fill gaps in the design to ensure that all power nets are connected and the spacing requirements are met.

- Before routing, you can
  - Insert standard cell fillers
  - Insert end cap cells
- After routing, you can
  - Insert well fillers
  - Insert pad fillers

The following sections describe how to insert these cells.

## **Inserting Standard Cell Fillers**

You can fill empty spaces in the standard cell rows with instances of reference filler cells to make sure all power nets are connected. One method of improving the stability of the power supply is to add decoupling capacitors as filler cells.

One method of improving the stability of the power supply is to add decoupling capacitors as filler cells. However, these filler cells often contain metal internally, and they can cause a short or a spacing rule violation with existing metal routes in the design. During insertion, filler cells with metal are retained only when they do not cause DRC violations.

To insert standard cell fillers,

- 1. (Optional) Define the standard cell filler rules by using the set\_left\_right\_filler\_rule command to define the left and right filler rules. These rules specify the filler cell to insert immediately to the left and right, respectively, of specific standard cells.
- 2. Use the insert\_stdcell\_filler command (or choose Finishing > Insert Standard Cell Filler in the GUI) to insert the standard cell fillers.

The following sections provide more information about these steps.

## **Defining the Filler Rules**

The left and right filler rules specify the filler cell to insert to the immediate left and immediate right, respectively, of specific standard cells. You use the set\_left\_right\_filler\_rule command to define these rules.

If there is only a single site between two standard cells, the rule used to fill that site depends on whether the references for the standard cells are the same or different. If the references for the two standard cells are the same, the tool uses the rules for the cell on the left and the rules for the cell on the right are ignored. If the references are different, the tool uses the rule that was defined first.

To report the right and left filler rules defined for your design, run the report\_left\_right\_filler\_rule command. The report shows the rules and the order in which they were defined.

By default, the left and right filler cells have a north (N) orientation or flipped-south (FS) orientation when the rows are flipped. You can choose to have the left and right filler cells follow the orientation of the standard cell by using the <code>set\_left\_right\_filler\_rule-follow\_stdcell\_orientation</code> option.

## **Inserting Filler Cells**

To insert standard cell fillers, use the <code>insert\_stdcell\_filler</code> command or choose Finishing > Insert Standard Cell Filler in the GUI. Table 4-6 shows the available options.

Table 4-6 Options for Inserting the Filler Cells

| Option                                | Description                                                   |
|---------------------------------------|---------------------------------------------------------------|
| -cell_without_metal                   | Specifies the list of filler cells to use.                    |
| -cell_with_metal                      | Specifies the master filler cells to use.                     |
| -bounding_box                         | Specifies the rectangular region to insert filler cells.      |
| -dont_respect_hard_placement_blockage | Specifies whether to respect hard placement blockage.         |
| -dont_respect_soft_placement_blockage | Specifies whether to respect soft placement blockage.         |
| -between_std_cells_only               | Inserts filler cells between two standard cells only.         |
| -randomize                            | Specifies whether to randomize the selection of filler cells. |

Table 4-6 Options for Inserting the Filler Cells (Continued)

| Option                     | Description                                                                          |
|----------------------------|--------------------------------------------------------------------------------------|
| -respect_overlap           | Specifies whether to respect standard-cell overlap check points.                     |
| -cell_without_metal_prefix | Inserts a prefix to the instance names of the filler cells without metal.            |
| -cell_with_metal_prefix    | Inserts a prefix to the instance names of the filler cells with metal.               |
| -avoid_layers              | Prevents insertion of filler cells under the specified metal layers.                 |
| -connect_to_power          | Specifies the power connection.                                                      |
| -connect_to_ground         | Specifies the ground connection.                                                     |
| -voltage_area              | Specifies the voltage areas to insert filler cells.                                  |
| -vt_filler                 | Specifies the threshold voltage cells to be used as voltage threshold fillers.       |
| -check_only                | Runs the command in checking mode, rather than insertion mode.                       |
| -restore_filler_snapshot   | Restores the filler cell placement of the snapshot previously created.               |
| -vt_filler_prefix          | Specifies the prefix for the collection of threshold voltage fillers to be inserted. |
| -respect_keepout           | Specifies whether to respect keepout margins.                                        |

The following example fills empty spaces between standard cells with filler cells FILL\_4X, FILL\_2X, and FILL\_1X, in that order of preference, in the bounding box with corners at (10,10) and (5000,5000). By specifying the filler cells from largest to smallest, the total number of filler cells is minimized by adding the larger filler cells first. Cells with metal are used where they do not cause DRC violations and cells without metal are used otherwise.

```
icc_shell> insert_stdcell_filler \
   -cell_without_metal {FILL_4X FILL_2X FILL_1X} \
   -cell_with_metal {FILL_4XM FILL_2XM FILL_1XM} \
   -bounding_box {{10.0 10.0} {5000.0 5000.0}} \
   -between_std_cells_only
```

For more information about the insert\_stdcell\_filler command, see the man page.

## **Removing Filler Cells**

To remove standard cell fillers, use the <code>remove\_stdcell\_filler -stdcell</code> command (or choose Finishing > Remove Fillers and select "Standard Cell" in the "Filler type" area in the GUI). By default, the filler cells are removed for the whole chip. You can optionally specify a bounding box from which to remove filler cells.

When filler cells are added after signal routing, you can remove all the filler cells that have routing design rule violations. To remove standard cell fillers with violations, use the remove\_filler\_with\_violation command (or choose Finishing > Remove Fillers With Violation in the GUI). You can restrict the removal to specific instances by using the -name option.

## **Reporting Filler Cells**

To report the type of filler cells and their locations, use the report\_filler\_placement command.

The command syntax is

```
report_filler_placement -lib_cell lib_cell_list [-abut]
```

Use the <code>-lib\_cells</code> option to specify the type of filler cells that you want to report in your design. To report only the adjacent filler cells that form a consecutive pair in a cell row, use the <code>-abut</code> option. For example,

```
icc_shell> report_filler_placement -lib_cell FILL1BWP -abut
```

The example reports only the consecutive filler cells named FILL1BWP and their locations in the design.

## **Inserting End Caps**

After placing standard cells and before routing, you can add end cap cells at both ends of a cell row. Typically, an end cap cell is a nonlogic cell that serves a certain purpose for the row such as providing a decoupling capacitor for the power rail. Because the IC Compiler tool accepts any standard cell as an end cap, you should specify a suitable end cap cell.

To insert end caps, use the <code>add\_end\_cap</code> command or choose Finishing > Insert End Cap in the GUI. You must specify the cell to use for the end caps by using the <code>-lib\_cell</code> option. For example,

```
icc_shell> add_end_cap -lib_cell MY_END_CAP
```

By default, the command places the specified library cells in their default orientation at both ends of the horizontal cell rows without considering padding, blockages, or keepouts. To add end caps to only one end, specify which end by using the <code>-mode</code> option. To add end caps only at the left end, specify the <code>-mode bottom\_left</code> option. To add end caps only at the right end, specify the <code>-mode upper\_right</code> option.

To specify the cells to add as vertical end caps, use the <code>-vertical\_cells</code> option, which inserts cells in the specified order and avoids unfilled space at the end of a cell row. When you add both horizontal and vertical end cap cells, you can fill the corners where the horizontal and vertical end caps meet by specifying the <code>-fill\_corner</code> option, changing it from its default of off. The <code>-fill\_corner</code> option takes effect only when you use it with the <code>-vertical\_cells</code> option.

By default, if a voltage area has no guard bands, the <code>add\_end\_cap</code> command ignores the voltage area boundaries during end cap insertion. To insert horizontal end caps at both sides of a vertical voltage area boundary, use the <code>-at\_va\_boundary</code> option.

By default, the add\_end\_cap command ignores the plan group boundaries during end cap insertion. To insert horizontal end caps at both sides of a vertical plan group boundary, use the -at plan group boundary option.

To flip the orientation of the end cap cells, use the <code>-mirror</code> option. The <code>-mirror</code> option applies to horizontal end caps only. To prevent the command from placing end caps inside padding areas, blockages, or keepouts, use the <code>-respect\_padding</code>, <code>-respect\_blockage</code>, and <code>-respect\_keepout</code> options respectively.

When you specify the <code>-next\_to\_fixed</code> option, the command treats a fixed cell abutting the boundary as a macro and creates a horizontal end cap next to the fixed cell. Other fixed cells are ignored by this option. This option cannot be used with the <code>-skip\_fixed</code> option.

During end cap insertion, the add\_end\_cap command ignores both hard and soft blockages by default. If you specify the <code>-respect\_blockage</code> option, the command respects both hard and soft blockages. To ignore only soft blockages, use the <code>-ignore\_soft\_blockage</code> option. The <code>-ignore\_soft\_blockage</code> option must be used with the <code>-respect\_blockage</code> option. When you specify both options, the command respects hard blockages but ignores soft

blockages. If you specify only the <code>-ignore\_soft\_blockage</code> option, the command issues an error.

You can remove end cap cells from your design by using the remove\_stdcell\_filler -end cap command.

## **Inserting Well Fillers**

After routing is complete, you can fill small gaps that violate the spacing rule for the well layer with well filler cells. You can fill gaps between cells in the same row or between rows.

To insert well fillers, use the <code>insert\_well\_filler</code> command (or choose Finishing > Insert Well Filler in the GUI).

The command syntax is

```
insert_well_filler
   -layer layer_name_or_number
   [-ignore_PRboundary]
   [-fill_gaps_smaller_than gap_size]
   [-higher_edge min | max]
   [-lower_edge min | max]
   [-gap_type {tt | bb | tb | bt}]
   [-respect_blockages]
   [-row_overlap {row_overlap_value}]
   [-min_gap {min_gap_distance}]
   [-max_gap {max_gap_distance}]
   [-enclosure_only width]
```

#### For example,

```
icc_shell> insert_well_filler -layer 10 \
   -fill_gaps_smaller_than 3.0 \
   -higher_edge "max" -lower_edge "min"
```

This example adds well filler on layer 10 for gaps smaller than 3.0 microns. If the wells from the two standard cells do not line up, the command creates the largest fill box by using the larger top edge and the smaller bottom edge.

By default, only the gaps between standard cells within a row are filled. To fill gaps between rows, use the -gap type option and set it to tt, bb, tb, or bt.

The <code>-higher\_edge</code> and <code>-lower\_edge</code> options specify how to align the well filler with the wells in the two standard cells when the wells in the cells do not line up. Figure 4-3 shows the alignments and fill boxes that occur as a result of the various settings.

Figure 4-3 Filler Alignment



The insert\_well\_filler command also has options to specify the following:

- Whether to ignore the PR boundary layer (layer 207) that extends outside a cell
- Whether to respect placement blockages when the -gap\_type option is used
- The amount of row overlap between the row and the gap when the -gap\_type option is used
- The minimum and maximum gap sizes that are filled when the -gap type option is used
- · Whether to insert a well enclosure instead of well fill and, if so, the enclosure width

To remove well fillers, use the remove\_well\_filler command (or choose Finishing > Remove Well Fillers in the GUI).

## **Inserting Pad Fillers**

After routing is complete, you can fill gaps in the pad ring with instances of pad filler cells. These are dummy pad cells that you can use to control the pad spacing and complement the n-well taps in pads. You should complete the routing process before you add pad filler cells.

To insert pad fillers, use the <code>insert\_pad\_filler</code> command (or choose Finishing > Insert Pad Filler in the GUI). This is the command syntax:

```
insert_pad_filler
  -cell lib_cells
  [-overlap_cell overlap_lib_cells]
  [-voltage_area voltage_area_list]
  [-bounding_box rectangle]
  [-prefix prefix]
  [-no_left]
  [-no_right]
  [-no_bottom]
  [-no_top]
```

#### For example,

```
icc_shell> insert_pad_filler -cell "PFILL_2X PFILL_1X" \
    -overlap_cell "PFILL_1X" -voltage_area {V1}
```

This example inserts pad filler cells PFILL\_2X and PFILL\_1X on the pad ring, with preference for PFILL\_2X because it is listed first, inside voltage area V1 only. The PFILL\_1X cell is allowed to overlap other pad filler cells to fill gaps that are too small for any pad filler cell.

The command also has options to restrict pad filler insertion to a specified rectangular area, to specify pad filler instance naming conventions, and to exclude pad filler insertion from left, right, top, or bottom boundaries.

To remove pad fillers, use the <code>remove\_stdcell\_filler-pad</code> command (or choose Finishing > Remove Fillers in the GUI and select "Pad" in the "Filler type" area). By default, pad fillers are removed for the whole chip. You can optionally specify a bounding box from which to remove pad fillers.

## **Inserting Metal Fill**

After routing, you can fill the empty space in the design with metal wires to meet the metal density rules required by most fabrication processes. Before inserting metal fill, the design should be close to meeting timing and have only a very few or no DRC violations.

When you define minimum and maximum metal density rules in the technology file, the tool tries to create fill within the specified ranges.

The IC Compiler tool supports both real and emulation metal fill extraction.

- To perform emulation metal fill extraction, you must specify the emulation TLUPlus files by using the -max\_emulation\_tluplus and -min\_emulation\_tluplus options of the set tlu plus files command.
- To perform real metal fill extraction, you must specify the

  -real\_metalfill\_extraction option of the set\_extraction\_options command.

  The tool can treat the metal fill polygons as either floating or grounded. You can either specify how to treat the metal fill polygons by using the floating or grounded keyword or let the tool determine the treatment, based on the fill wire track property, by using the auto keyword. When you use the none keyword, which is the default, fill is not considered during extraction.

In addition to specifying the <code>-real\_metalfill\_extraction</code> option, you must specify TLUPlus files without any emulation information, using the <code>set\_tlu\_plus\_files</code> command.

#### Note:

The tool uses nonemulation TLUPlus files when set\_extraction\_options -real\_metalfill\_extraction is set to auto, floating, or grounded. Therefore, you should select real metal fill for extraction only after the metal fill objects have been added.

You can insert metal fill by using the internal IC Compiler metal fill capability or by invoking the external IC Validator or Hercules metal fill capability. To use the internal IC Compiler metal fill capability, run the <code>insert\_metal\_filler</code> command or choose Finishing > Insert Metal Filler in the GUI. To invoke the external IC Validator or Hercules metal fill capability, use the <code>signoff\_metal\_fill</code> command or choose Finishing > Signoff Metal Fill in the GUI. Using the IC Validator or Hercules metal fill capability ensures DRC conformance and produces better quality of results but requires an IC Validator or Hercules license.

## **IC Compiler Metal Fill**

To perform metal density filling in the IC Compiler tool, use the <code>insert\_metal\_filler</code> command (or choose Finishing > Insert Metal Filler in the GUI). This is the command syntax:

```
insert metal filler
   [-out self | cellview name]
   [-purge]
   [-bounding_box {{llx lly} {urx ury}}]
   [-dont overwrite]
   [-timing_driven]
   [-insert_as_instance instance_name]
   [-tie_to_net none | ground | net_name]
   [-create_floating_vias]
   [-floating_via_ftr_spacing]
   [-routing space route space]
   [-from metal from metal number]
   [-to metal to metal number]
   [-width {layer width}]
   [-space {layer space_between_fills}]
   [-min_length {layer min_length}]
   [-max length {layer max length}]
   [-space_to_route {layer keep_from_metal_space}]
   [-space_to_pg {layer keep_from_pg_nets_space}]
   [-stagger {layer}]
   [-x_offset {layer x_distance}]
   [-y_offset {layer y_distance}]
   [-dont snap fill to track]
   [-fill poly]
   [-distance_to_boundary poly_to_cell_distance]
```

You can use the -width, -space, -min\_length, -max\_length, -space\_to\_route, -space\_to\_pg, -x\_offset, and -y\_offset options to specify the fill characteristics of one or more layers. You specify each characteristic using one or more pairs of values. Each pair consists of a layer name such as poly, M1, or M2, followed by the value. For example,

```
icc_shell> insert_metal_filler \
   -width {M1 0.1} \
   -space {poly 0.1} \
   -min_length {M1 2 M2 2 M3 2} \
   -max_length {M1 10 M2 10 M3 10}
```

This example fills tracks using width 0.1 for metal 1 and spacing 0.1 for poly, with lengths ranging from 2 to 10 for metal 1, metal 2, and metal 3. The default values are used for the remaining metal fill characteristics not specified explicitly in the command.

These are the fill characteristics you can set:

- -width: the width of fill tracks
- space: the spacing between fill tracks on the same layer

- -min\_length: the minimum length of fill tracks
- -max\_length: the maximum length of fill tracks
- -space\_to\_route: the space to keep away from existing metal
- -space to pg: the space to keep away from power and ground nets
- -x offset: the x-offset for staggered fill tracks
- -y\_offset: the y-offset for staggered fill tracks

Fill tracks are staggered if you use the  $-x_offset$ ,  $-y_offset$ , or -stagger option. In that case, if you do not want the fill snapped to wire tracks, use the  $-dont_snap_fill_to_track$  option.

Use the <code>-purge</code> option to remove, rather than insert, metal fill. You can remove fill-track objects from a specified range of layers using <code>-from\_metal</code> and <code>-to\_metal</code>. Otherwise, the <code>-purge</code> option removes fill-track objects from all layers.

The insert\_metal\_filler command also has options to specify the following:

- Whether to modify the current cell (the default) or to write the output to a new cell
- A bounding box in which to insert metal fill
- The net to which the metal fill must be connected
- The space between normal routing wires and the fill metal, expressed as a multiplier of the minimum spacing for the layer (default 1.0)
- The range of layer numbers to fill
- Whether to fill poly layers as well as metal layers (by default, only metal layers are filled)
- Whether to create floating vias, and if so, the required spacing
- Whether to check for timing effects during metal fill
- The spacing of poly to the cell boundary

## Signoff Metal Fill

Without leaving the IC Compiler tool, you can invoke the IC Validator or Hercules tool to create, view, and change metal fill by using the <code>signoff\_metal\_fill</code> command or by choosing Finishing > Signoff Metal Fill in the GUI. Using the external IC Validator or Hercules metal fill capability ensures DRC conformance and produces the best quality of results. However, it requires a separate IC Validator or Hercules license.

To use the signoff\_metal\_fill command to insert metal fill,

- Set up the validation tool environment.
- Set up the physical signoff options.
- Set up distributed processing.
- Run the signoff\_metal\_fill command.

The following sections describe these tasks.

## **Setting Up the Validation Tool Environment**

You can use either the IC Validator or Hercules tool to insert metal fill with the signoff\_metal\_fill command. For designs that are at the 32-nm process node or below, you should use the IC Validator tool for metal fill.

#### **Setting Up the IC Validator Environment**

To use the IC Validator tool when running the signoff\_metal\_fill command, you must have an IC Validator license, and you must specify the location of the IC Validator executable by setting the ICV\_HOME\_DIR environment variable. You can set this variable in your .cshrc file. To specify the location of the IC Validator executable, use commands similar to those shown in the following example:

```
setenv ICV_HOME_DIR /root_dir/icv
set path = ($ICV_HOME_DIR/bin/AMD.64 $path)
```

You must ensure that the version of the IC Validator executable that you specify is compatible with the IC Compiler version that you are using. For more information about the IC Validator tool, see the IC Validator documentation, which is available on SolvNet.

The IC Validator tool can generate a compressed hierarchical FILL view file, instead of the default hierarchical FILL view file. The compressed hierarchical FILL view reduces the size of the FILL view file without increasing runtime or memory requirements. To use the compressed hierarchical FILL view file instead of the default hierarchical FILL view file, set

the ICV\_ENABLE\_GDSREF environment variable to 1 before invoking the IC Compiler tool. You can also set this variable in your .cshrc file.

```
setenv ICV_ENABLE_GDSREF 1
```

#### **Setting Up the Hercules Environment**

To use the Hercules tool when running the <code>signoff\_metal\_fill</code> command, you must have a Hercules license, and you must specify the location of the Hercules executable by setting the <code>HERCULES\_HOME\_DIR</code> environment variable. You can set this variable in your .cshrc file. For example.

```
setenv HERCULES_HOME_DIR /root_dir/hercules
set path = ($path $HERCULES_HOME_DIR/bin/AMD.64)
```

You must ensure that the version of the Hercules executable that you specify is compatible with the IC Compiler version that you are using. For more information about the Hercules tool, see the Hercules documentation, which is available on SolvNet.

## **Setting Up the Physical Signoff Options**

To prepare for signoff metal fill, use the <code>set\_physical\_signoff\_options</code> command to specify the name of the executable, either <code>icv</code> or <code>hercules</code>, and the runset file for metal fill. For example,

```
icc_shell> set_physical_signoff_options -exec_cmd icv \
   -fill_runset my_fill_runset_file
```

You can report the option settings by using the report\_physical\_signoff\_options command.

## **Setting Up Distributed Processing**

By default, the <code>signoff\_metal\_fill</code> command uses a single process to perform metal fill insertion. To reduce the turnaround time for metal fill insertion, you can use distributed processing. To enable distributed processing, you must define the distributed processing configuration by using the <code>set\_host\_options</code> command.

If you have defined more than one distributed processing configuration with the set\_host\_options command, the signoff\_metal\_fill command selects the IC Validator processing method in the following order of priority:

1. Job submission through a user-defined distributed processing script

To enable job submission using your own script with the set\_host\_options command, use the -submit\_command option to specify the location of your job submission script. For example, to specify a configuration named custom4 that enables a maximum of four processes using your job submission script, enter the following command:

```
icc_shell> set_host_options -name custom4 -num_processes 4 \
    -submit_command /usr/local/bin/my_submit_command
```

2. Job submission through the Load Sharing Facility (LSF) or the Sun Grid Engine (SGE)

To enable LSF or SGE job submission with the  $set_host_options$  command, use the -pool option to specify the mode and the -num\_processes option to specify the maximum number of processes.

For example, to specify a configuration named lsf4 that enables a maximum of four processes using LSF, enter the following command:

```
icc_shell> set_host_options -name lsf4 -pool lsf -num processes 4
```

To specify a configuration named grd4 that enables a maximum of four processes using SGE, enter the following command:

```
icc_shell> set_host_options -name grd4 -pool grd -num_processes 4
```

3. Distributed processing on the specified hosts

To enable distributed processing with the set\_host\_options command, specify the hosts to use and use the -num\_processes option to specify the maximum number of processes on each host. For example, to specify a configuration named dp4 that enables a maximum of four processes, with a maximum of two processes each on machineA and machineB, enter the following command:

```
icc_shell> set_host_options -name dp4 -num_processes 2 \
{machineA machineB}
```

4. Multithreading

To enable multithreading on the current machine with the set\_host\_options command, use the -max\_cores option to specify the number of threads. For example, to specify a configuration named mt4 that enables a maximum of four threads on the current machine, enter the following command:

```
icc_shell> set_host_options -name mt4 -max_cores 4
```

To ensure that you are using the intended distributed processing configuration, remove the current configurations by using the remove host options command before defining the

distributed processing configuration for the signoff\_metal\_fill command. To report the current distributed processing configurations, use the report\_host\_options command.

For more information about the set\_host\_options command, see Chapter 2, "Working With the IC Compiler Tool," in the IC Compiler Implementation User Guide.

## Running the signoff\_metal\_fill Command

Before you run the <code>signoff\_metal\_fill</code> command, the design must be fully routed and have only a very few or no DRC violations, and you must save the most recent revision of the design in a CEL view. The IC Validator or Hercules tool reads and operates on the design data in CEL, FRAM, and FILL views stored on disk, not on the current design in IC Compiler memory.

You can use the signoff\_metal\_fill command to perform the following tasks, which are described in this section:

- Standard Metal Fill Insertion
- Timing-Driven Metal Fill Insertion
- Metal Fill Removal
- Post-ECO Metal Fill Cleanup

The following sections describe these tasks.

#### Note:

When you run the <code>signoff\_metal\_fill</code> command, you can specify additional options for the Hercules or IC Validator command line by using the <code>-user\_defined\_options</code> option. The string that you specify in this option is added to the command line used to invoke metal fill insertion in the Hercules or IC Validator tool. The IC Compiler tool does not perform any checking on the specified string.

#### Standard Metal Fill Insertion

Standard metal fill insertion is the default mode for the signoff\_metal\_fill command. If you run the signoff\_metal\_fill command without any options, it performs the following tasks:

Removes existing metal fill from the entire design.

You can skip this step and perform incremental metal fill insertion by using the <code>-append</code> option (or by selecting "Keep existing metal fills in output view" in the Fill Options tab in the GUI). When you perform incremental metal fill insertion, you must use the default FILL view.

• Inserts metal fill in the empty regions for the whole design using the metal fill mode specified in the runset file, which is either hierarchical or flat.

You can force the use of the flat metal fill mode by using the -mode flat option.

Stores the inserted metal fill information in the default FILL view.

You can specify a different name for the FILL view by using the <code>-output\_view</code> option (or by entering the name in the "Output FILL view name" text box in the Fill Options tab in the GUI).

You can restrict the metal fill insertion to specific layers or specific regions of the design.

Specifying the layers for metal fill insertion

By default, the <code>signoff\_metal\_fill</code> command inserts metal fill on all the metal routing layers. To perform metal fill insertion on a specific set of metal and via layers, specify the layers in the <code>-select\_layers</code> option (or select them in the list in the "Insert/Remove metal fills in selected layers" area in the GUI).

By default, when you use this option, the <code>signoff\_metal\_fill</code> command removes all existing metal fill from the design and then inserts metal fill only on the specified layers. To keep the existing metal fill on the unspecified layers and to redo metal fill insertion only on the specified layers, use the <code>-eco</code> option. If you use the <code>-eco</code> option, you must use the default FILL view.

For example, to remove all metal fill on layers M1 and M3 and refill those two layers without affecting the metal fill on other layers, enter the following command:

```
icc shell> signoff metal fill -eco -select layers {M1 M3}
```

Specifying the regions for metal fill insertion

By default, the signoff\_metal\_fill command inserts metal fill for the whole chip. You can restrict metal fill insertion to one or more regions of the design by specifying regions

in which to insert metal fill or by specifying regions in which to prevent metal fill insertion or both.

To restrict metal fill insertion to specific regions of the design, use the <code>-bounding\_boxes</code> option to specify the coordinates of each region in which to insert metal fill. You can specify multiple areas by specifying the coordinates for each area. If you are using the GUI, identify the regions in which to insert metal fill by selecting "Selected areas" and specifying the coordinates of each bounding box in the "Bounding Boxes" list. To specify the coordinates for a region, either draw the bounding box or enter the x- and y-coordinates of the box. For each region, you can also enable or disable snapping. If snapping is enabled, you can specify that the bounding box should snap to the minimum grid (the default), placement site, routing track, middle routing track, or user grid.

#### Note:

The bounding box coordinates passed to the Hercules or IC Validator tool in the  ${\tt METAL\_FILL\_SELECT\_WINDOW}$  parameter are enlarged by 1  $\mu m$  to avoid DRC violations on the boundary of the specified regions during metal fill insertion. The actual metal fill insertion occurs within the regions specified by the <code>-bounding\_boxes</code> option.

In addition, when you use the <code>-bounding\_boxes</code> option, the <code>signoff\_metal\_fill</code> command always uses flat metal fill mode.

To prevent metal fill insertion in specific regions, use the <code>-excluded\_bounding\_boxes</code> option or select "Excluded areas" and specify the coordinates of each bounding box in the "Bounding Boxes" list in the GUI.

By default, when you use these options, the <code>signoff\_metal\_fill</code> command removes all existing metal fill from the design and then inserts metal fill only in the specified regions. To redo metal fill insertion only on the specified regions and keep the other existing metal fill, use the <code>-eco</code> option. If you use the <code>-eco</code> option, you must use the default FILL view.

For example, to remove all metal fill from the design and then fill all empty regions outside the bounding box with corners at (100,150) and (300,200), enter the following command:

```
icc_shell> signoff_metal_fill \
   -excluded_bounding_boxes {{100 150}} {300 200}}
```

#### **Timing-Driven Metal Fill Insertion**

Timing-driven metal fill insertion inserts metal fill in the specified regions of the design, except around timing-critical nets. You can either explicitly specify the timing-critical nets or you can specify slack thresholds that enable the tool to determine the timing-critical nets automatically.

#### Note:

Timing-driven metal fill insertion is supported only in the IC Validator tool.

To explicitly specify the critical nets, use the <code>-timing\_preserve\_nets</code> option. To specify a setup slack threshold, use the <code>-timing\_preserve\_setup\_slack\_threshold</code> option. To specify a hold slack threshold, use the <code>-timing\_preserve\_hold\_slack\_threshold</code> option. If you are using the GUI, you can set these values in the Timing Preserve tab.

By default, the minimum spacing between a critical net and metal fill is twice the minimum spacing for the layer on which the net occurs. In addition, no metal fill is inserted within the minimum spacing around the vertical extension of the net on the layers above and below the net. You can specify a different same-layer minimum spacing requirement by using the <code>-space\_to\_critical\_nets</code> option. You can allow metal fill insertion within the vertical extension of the net on the adjacent layers by using the <code>-fill\_over\_critical\_nets</code> option.

If you specify a large minimum spacing requirement, timing-driven metal fill insertion might cause density errors. To prevent the introduction of density errors during timing-driven metal fill insertion, use the <code>-fix\_density\_errors</code> true option. Note that this option requires that the metal density rules are defined in the technology file. For information about defining metal density rules in the technology file, see the *IC Compiler Technology File and Routing Rules Reference Manual*.

#### Note:

You can specify the regions in which to perform timing-driven metal fill insertion, as described in "Standard Metal Fill Insertion" on page 4-44; however, you cannot specify the layers. When performing timing-driven metal fill insertion, the <code>signoff\_metal\_fill</code> command inserts metal fill on all routing layers.

During timing-driven metal fill insertion, the signoff metal fill command

- Performs timing analysis, including multicorner-multimode analysis, to minimize timing impact.
- Identifies timing-critical nets based on the options you specify.
- Invokes the IC Validator tool to perform metal fill insertion.

When you perform timing-driven metal fill insertion, you must always use the default FILL view.

By default, when you run timing-driven metal fill insertion, the <code>signoff\_metal\_fill</code> command removes all existing metal fill from the design and then inserts metal fill in the specified regions, except in the areas around the critical nets. To do timing-driven metal fill insertion on the specified regions and keep the other existing metal fill, use the <code>-eco</code> option. You cannot use <code>-append</code> option when performing timing-driven metal fill insertion.

#### **Metal Fill Removal**

To remove all metal fill from the design, use the <code>-purge</code> option (or select "Remove fills" in the GUI). When you use this option, you must use the default FILL view. You can specify the layers on which to remove the metal fill by using the <code>-select\_layers</code> option. You can specify the regions from which to remove the metal fill by using the <code>-bounding\_boxes</code> option. No other options are supported with the <code>-purge</code> option. For more information about specifying the layers and regions for metal fill removal, see "Standard Metal Fill Insertion" on page 4-44.

### **Post-ECO Metal Fill Cleanup**

After you perform metal fill insertion and ECO routing, use the signoff\_metal\_fill command to remove any metal fill that overlaps a net. You can use the following methods to remove the metal fill:

Remove the metal fill based on foundry-specific rules

The signoff\_metal\_fill command supports metal fill removal based on the fill spacing rules for several foundry and node combinations. To determine the supported foundry and node combinations, use the signoff\_metal\_fill -remove overlap by rules list command.

To remove the metal fill that overlaps any net based on foundry-specific rules,

1. Prepare the fill removal runset include file.

The fill removal runset include file specifies foundry's fill spacing rule values. For details about how to prepare this file, see SolvNet article 035828.

2. Specify the fill removal runset include file by using the -fill\_removal\_runset\_include\_file option with the set physical signoff options command.

```
icc_shell> set_physical_signoff_options \
   -fill removal runset include file file name
```

3. Perform fill removal by using the <code>-remove\_overlap\_by\_rules</code> option with the <code>signoff\_metal\_fill</code> command to specify one of the keywords returned by the <code>signoff\_metal\_fill</code> <code>-remove\_overlap\_by\_rules</code> <code>list</code> command.

```
icc_shell> signoff_metal_fill \
   -remove_overlap_by_rules foundry_node
```

Remove the metal fill based on minimum spacing

The signoff\_metal\_fill command supports metal fill removal based on either the minimum spacing rules defined in the technology library or user-specified minimum spacing values. When removing metal fill based on the minimum spacing rules defined in the technology library, the tool removes the metal fill around each net such that there

is no metal fill within twice the minimum spacing for the layer on which the net occurs. You can either remove the metal fill on all nets or only on specified nets.

To remove the metal fill that overlaps any net based on the minimum spacing rules, use the -remove\_overlap\_by\_rules min\_spacing option. To use user-defined spacing values instead of the minimum spacing rules, you must also use the -space to critical nets option to specify the spacing requirements for each layer.

For example, to use the minimum spacing rules to remove the metal fill that overlaps the existing nets, enter the following command:

```
icc_shell> signoff_metal_fill -remove_overlap_by_rules min_spacing
```

To remove the metal fill that overlaps specific nets based on the minimum spacing rules, use the <code>-remove\_overlap\_with\_nets</code> <code>nets</code> option. To use user-defined spacing values instead of the minimum spacing rules, you must also use the

-space\_to\_critical\_nets option to specify the spacing requirements for each layer.

For example, to remove the metal fill that overlaps the n1 net with a minimum spacing of 0.2 microns on the M1, M2, and M3 metal layers, enter the following command:

```
icc_shell> signoff_metal_fill -remove_overlap_with_nets n1 \
    -space_to_critical_nets {M1 0.2 M2 0.2 M3 0.2}
```

#### Note:

You can specify the layers on which to remove the metal fill, as described in "Standard Metal Fill Insertion" on page 4-44; however, you cannot specify the regions. When removing overlapping metal fill, the <code>signoff\_metal\_fill</code> command removes the metal fill around the specified nets.

For example, to use the minimum spacing rules to remove the metal fill on layers M1, M2, and M3 that overlaps existing nets, enter the following command:

```
icc_shell> signoff_metal_fill -remove_overlap_by_rules min_spacing \
   -select_layers {M1 M2 M3} \
```

## **Performing Notch and Gap Filling**

After routing is complete, you can fill notches and gaps that are smaller than the minimum distance limit between objects of the same net on the same layer. The generated notch-and-gap-filling information is stored in the FILL view cell and can be used when you translate your design data to GDSII format.

To perform notch and gap filling, use the insert\_ng\_filler command (or choose Finishing > Insert Notch Gap Filler in the GUI). This is the command syntax:

```
insert_ng_filler
  [-include_existing_notch_gap_fill_cell]
  [-skip_filling_child_cell]
  [-dont_apply_fat_wire_rule]
  [-dont_fill_corner_to_corner]
  [-output outname]
  [-notch_layer_data_type notch_datatype]
  [-gap_layer_data_type gap_datatype]
  [-layers layer_list]
```

#### For example,

```
icc_shell> insert_ng_filler -include_existing_notch_gap_fill_cell \
   -dont apply fat wire rule -output test.err
```

The command has options to specify the following:

- Whether to use existing notch and gap cells existing in the netlist and having the .FILL extension
- Whether to skip reading the child cell's port data and applying fill on those ports
- Whether to ignore the fat wire rule when filling notches and gaps
- Whether to ignore corner-to-corner notch errors
- Whether to save the notch and gap errors into a file
- The notch layer data type and gap layer data type numbers
- The list of layers for which to fill notches and gaps

You can also perform notch and gap filling during the search-and-repair process. Doing so enables the router to correct DRC violations as it fills notches and gaps, including violations of 90-nm rules. Set the relevant routing option by using the set\_route\_options
-same\_net\_notch check\_and fix command (or by choosing Route > Routing Setup > Set Route Options in the GUI and selecting the corresponding option under the Miscellaneous tab). This setting instructs the router to fix same-net notch violations during the search-and-repair process. For more information, see "Search and Repair" on page 3-26.

## **Lithography Compliance Checking**

Lithography compliance checking (LCC) is a method of increasing yields by analyzing the chip layout in detail for conditions that can lead to lithography defects and that cannot be fixed by ordinary optical proximity correction methods. PrimeYield LCC is a Synopsys product designed to find these conditions and generate reports on LCC hotspots, which are locations of potential defects. It simulates the full resolution-enhancement technology tape-out flow using the same production-baseline technology and manufacturing models as those used by foundries and integrated device manufacturers. It reports the location and type of each occurrence of lithographic sensitivity to potential defects such as line-end narrowing and line-end bridging. It ranks these problems by severity and presents them for review.

In the IC Compiler tool, you can detect potential defect locations with the detect\_lcc\_hotspot command, which invokes PrimeYield LCC in the background to find the hotspots. You can view the reported hotspots in the IC Compiler GUI and fix them with the fix\_lcc\_hotspot command. The fixing command repairs the reported conditions by moving, filling, and widening routes and by adding, deleting, and moving vias; or in cases where these local fixing methods cannot be used effectively, it rips up and reroutes the problem net.

PrimeYield LCC licensing is required to use these commands. The PrimeYield LCC and Hercules version used by the IC Compiler tool must be the same as the version used to generate the LCC data files. For information about setting up and using the PrimeYield LCC tool, see the *PrimeYield LCC User Guide* provided with the PrimeYield LCC product.

Before running LCC detection, perform via optimization and critical area reduction and ensure that the design does not have any DRC violations.

## **Detecting LCC Hotspots**

The detect\_lcc\_hotspot command invokes PrimeYield to detect potential lithography-related defects. This is the command syntax:

```
detect_lcc_hotspot
    -lcc_file_path lcc_path_name
    -layers list_of_layers
    [-dp_hosts list_of_dp_hosts]

For example,
icc_shell> detect_lcc_hotspot \
    -lcc_file_path /LCC/full-chip \
    -layers {M2 M3 M4} \
    -dp_hosts {lin1 lin2 lin3 lin4 lin5 lin6 lin7 lin8}
```

This command performs full-chip LCC detection and produces two fixing guidance files in the working directory, out00 and fout00. These two files contains hotspot information and guidance for local fixing and reroute fixing. They are required to run the fix\_lcc\_hotspot command.

The hotspot detection process also produces an error view named *top\_cell\_name\_*lcc.err. You can open this error view in the GUI using Verification > Error Browser and view the hotspots in the current design. Each hotspot is highlighted as a DRC error.

In the <code>detect\_lcc\_hotspot</code> command, you must specify the full path name of the directory containing the PrimeYield LCC runset files necessary for full-chip LCC detection. For information about preparing runset files, see the <code>PrimeYield LCC User Guide</code> provided with the PrimeYield LCC product, or see the article "Using PrimeYield LCC," which is available as SolvNet article 023079. You must also specify the layers to be checked.

The detect\_lcc\_hotspot command requires distributed processing because of the long runtime for full-chip LCC detection. You can specify the machines to be used with the -dp\_hosts option, the .dprc file under the working directory, or the .dprc file specified under the *lcc path name* directory. Running hotspot detection on a single CPU is not supported.

The distributed processing engine used by the <code>detect\_lcc\_hotspot</code> command is different from that used by the <code>fix\_lcc\_hotspot</code> command and many other routing commands. You do not need to run the <code>set\_distributed\_route</code> command before the <code>detect\_lcc\_hotspot</code> command. If you run the <code>set\_distributed\_route</code> command, run the <code>remove\_distributed\_route</code> command before the <code>detect\_lcc\_hotspot</code> command to release the reserved network resources. Otherwise, the communication port between machines might become occupied and block distributed processing functionality.

## **Fixing LCC Hotspots**

The fix\_lcc\_hotspot command attempts to fix hotspots previously detected with the detect\_lcc\_hotspot command. To obtain maximum fixing quality and to ensure iteration convergence, the design must not have DRC violations. The two fixing guidance files generated by the detect\_lcc\_hotspot command, out00 and fout00, must be present the working directory.

This is the syntax of the LCC hotspot-fixing command:

```
fix_lcc_hotspot
    -lcc_file_path lcc_path_name
    [-types list_of_types]
    [-level level]
    [-num_loops number_of_loops]
    [-num_cpus number_of_cpus]

For example,

icc_shell> set_distributed_route \
    -jp_machines {linux1 linux2 linux3 linux4 linux5}

icc_shell> fix_lcc_hotspot \
    -lcc_file_path /root/LCC/Local-LCC \
    -types {line space lineend slotend} \
    -level 1 -num_cpus 10
```

Distributed processing is recommended because runtimes can be long. First run the set\_distributed\_route command to set up the machines to be used. Then, in the fix\_lcc\_hotspot command, set the -num\_cpus option to a value greater than 1. For more information about distributed routing, see the "Enabling Distributed Routing" on page 2-18.

In the  $fix_lcc_hotspot$  command, you must specify the full path name of the same LCC directory used by the  $detect_lcc_hotspot$  command. This is the directory containing the PrimeYield LCC runset files necessary for full-chip LCC detection. You can optionally specify the types of hotspots to fix, the hotspot severity levels to fix, the maximum number of fixing loops to attempt, and the number of CPUs to use.

The -types option specifies the types of hotspots to fix, which can be any combination of line, lineend, space, slotend, and voc (via overlay check). The default behavior is to fix all types of hotspots.

The -levels option specifies the severity levels to fix. If you use this option, the command attempts to fix only the hotspots having a severity number equal to or less than the specified number. Lower numbers represent the more severe hotspots.

There are two severity level systems, LCC-t and LCC-g. The IC Compiler tool gets the severity level system, either LCC-t or LCC-t, from the LCC runsets. You need to know which level system is being used so you can enter an appropriate level number. The LCC-g system

has the possible level values 1, 2, 3, 4, and 5. If you specify the <code>-levels</code> 3 option in this system, the command fixes only the hotspots having a severity level of 1, 2, or 3. The default maximum severity value for this system is 2.

The fix\_lcc\_hotspot command attempts to fix LCC hotspots using multiple iterations of fixing and rechecking. In each iteration, it first tries to fix hotspots by local-fixing and rerouting. New DRC violations or new LCC hotspots might occur as a result of fixing, so it performs internal DRC checking and launches LCC checking jobs to check the changed patterns. This process is repeated until there are no more LCC hotspots or DRC violations, or until the number of iterations reaches the maximum value specified by the -num\_loops option. Most designs that can converge do so in fewer than 10 iterations.

# Index

| A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | create_route_guide 2-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| add_end_cap command 4-33                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | create_routing_blockage 2-5 define_routing_rule 2-7 get_drc_errors 3-47                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| C Calibre interface 3-47 cell placement statistics 3-35 check_routeability command 1-3 chip finishing   adding end caps 4-33   displaying critical area heat maps 4-25 filling empty tracks with metal fill 4-37 filling notches and gaps 4-49 inserting pad fillers 4-36 inserting redundant vias 4-28 inserting standard cell fillers 4-29 inserting well fillers 4-34 performing wire spreading 4-26 performing wire widening 4-27 classic router enabling 2-2 flow 1-2 commands add_end_cap 4-33 check_routeability 1-3 | define_routing_rule 2-7 get_drc_errors 3-47 get_route_guides 2-4 get_routing_blockages 2-5 insert_metal_filler 4-38 insert_ng_filler 4-49 insert_pad_filler 4-36 insert_redundant_vias 4-28 insert_stdcell_filler 4-30 insert_well_filler 4-34 list_drc_error_types 3-48 optimize_wire_via 3-27 process_particle_probability_file 4-24, 4-25 read_drc_error_file 3-47 remove_filler_with_violation 4-32 remove_preferred_routing_direction 2-6 remove_route_by_type 2-13 remove_route_guide 2-5 remove_routing_blockage 2-5 remove_stdcell_filler     -pad 4-36     -stdcell 4-32 remove_well_filler 4-35 report_critical_area 4-23 |
| convert_wire_ends 3-36<br>create_auto_shield 3-33                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | report_design_physical 3-35 report_drc_error_type 3-48 report_error_coordinates 1-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| report_net_routing_rules 2-10             | customer support xiii                  |
|-------------------------------------------|----------------------------------------|
| report_physical_signoff_options 3-38      |                                        |
| report_preferred_direction 2-6            | D                                      |
| report_route_opt_strategy 3-6             |                                        |
| report_route_options 2-13                 | define_routing_rule command 2-7        |
| route_detail 3-26                         | design for manufacturing (DFM)         |
| route_global 3-24                         | critical area heat map displaying 4-25 |
| route_group 3-2                           | metal density filling 4-37             |
| route_search_repair 3-26                  | via doubling 4-28                      |
| route_spreadwires 4-26                    | wire spreading 4-26                    |
| route_track 3-25                          | wire widening 4-27                     |
| route_widen_wire 4-27                     | design rule violations                 |
| route_zrt_eco 3-34                        | analyzing                              |
| set_clock_tree_options 2-9                | error browser 3-48                     |
| set_distributed_route 2-19                | DRC query commands 3-47                |
| set_extraction_options 4-37               | design rules, routing                  |
| set_ignored_layers 2-11                   | metal density 4-37                     |
| set_left_right_filler_rule 4-30           | notch and gap filling 4-49             |
| set_net_aggressors 2-18                   | detail routing 3-26                    |
| set_net_routing_rule 2-9                  | distributed routing 2-18               |
| set_physical_signoff_options 3-38, 4-41   | 3                                      |
| set_preferred_routing_direction 2-6       | _                                      |
| set_route_mode_options 2-2                | E                                      |
| set_route_opt_strategy 3-5                | ECO routing 3-34                       |
| set_route_options 2-13                    | emulation metal fill extraction 4-37   |
| set_route_type 2-13                       | end cap                                |
| set_tlu_plus_files 4-37                   | adding 4-33                            |
| verify_drc 3-43                           | defined 4-33                           |
| verify_route 3-46                         | extraction                             |
| conventions for documentation xii         | real and emulation metal fill 4-37     |
| convert_wire_ends command 3-36            | Tour and officiation motal fill 1 of   |
| create_auto_shield command 3-33           | _                                      |
| create_route_guide command 2-3            | F                                      |
| create_routing_blockage command 2-5       | FILL view 4-49                         |
| critical area                             | fill, metal 4-37, 4-38, 4-40           |
| displaying heat maps 4-25                 | filler cell                            |
| encrypting and decrypting the particle    | inserting pad fillers 4-36             |
| probability function 4-24                 | inserting standard cell fillers 4-29   |
| crosstalk                                 | inserting well fillers 4-34            |
| reduction, during route_opt 3-8           | removing pad fillers 4-36              |
| crosstalk prevention, net aggressors 2-18 | removing standard cell fillers 4-32    |
|                                           | •                                      |

### removing well fillers 4-35

## G

get\_drc\_errors command 3-47
get\_route\_guides command 2-4
get\_routing\_blockages command 2-5
global routing
defined 3-24
running 3-24

## Н

Hercules
design rule checking
distributed 3-40
verify\_drc 3-43
environment, setting up 3-37
layer mapping file 3-39
metal fill 4-40

insert\_metal\_filler command 4-38 insert\_ng\_filler command 4-49 insert\_pad\_filler command 4-36 insert\_redundant\_vias command 4-28 insert\_stdcell\_filler command 4-30 insert\_well\_filler command 4-34

## L

list\_drc\_error\_types command 3-48

## M

Map Mode panel 4-25
metal density filling
inserting 4-37
metal fill 4-37, 4-38, 4-40
metal fill extraction, real and emulation 4-37

#### methodology 1-2

## Ν

net aggressors 2-18
net layer constraints, specifying 2-11
net shielding 3-32
nondefault routing rules
applying 2-8
defining 2-7
reporting 2-10
notch and gap filling 4-49

## 0

optimize\_wire\_via command 3-27

## P

pad filler
inserting 4-36
removing 4-36
physical signoff options
reporting 3-38
setting 3-38
placement
statistics 3-35
preferred routing direction
reporting 2-6
setting 2-6
prerequisites, routing 1-3
prerouting special nets 3-2
process\_particle\_probability\_file command
4-24, 4-25

## R

read\_drc\_error\_file command 3-47
real metal fill extraction 4-37
remove filler with violation command 4-32

| remove_preferred_routing_direction.command 2-6           | global 3-24<br>prerequisites 1-3                                       |  |  |
|----------------------------------------------------------|------------------------------------------------------------------------|--|--|
| remove_route_by_type command 2-13                        | running individual steps 3-23                                          |  |  |
| remove_route_guide command 2-5                           | special nets 3-2                                                       |  |  |
| remove_routing_blockage command 2-5                      | track assignment 3-25                                                  |  |  |
| remove stdcell filler command                            | verifying 3-36                                                         |  |  |
| -pad 4-36                                                | routing and optimization strategy                                      |  |  |
| -stdcell 4-32                                            | reporting 3-6                                                          |  |  |
| remove_well_filler command 4-35                          | setting 3-5                                                            |  |  |
| report_critical_area command 4-23                        | routing blockage                                                       |  |  |
| report_design_physical command 3-35                      | creating 2-5                                                           |  |  |
| report_drc_error_type command 3-48                       | finding 2-5                                                            |  |  |
| report_error_coordinates command 1-3                     | removing 2-5                                                           |  |  |
| report_net_routing_rules command 2-10                    | routing direction, setting preferred 2-6                               |  |  |
| report_physical_signoff_options command                  | routing layers                                                         |  |  |
| 3-38                                                     | specifying 2-11 routing options, setting 2-13                          |  |  |
| report_preferred_direction command 2-6                   | routing options, setting 2-13 routing rules (nondefault), defining 2-7 |  |  |
| report_route_opt_strategy command 3-6                    | routing rules (nondelault), defining 2-7                               |  |  |
| report_route_options command 2-13                        | routing statistics 3-33                                                |  |  |
| reporting                                                | removing 2-13                                                          |  |  |
| cell placement statistics 3-35                           | setting 2-13                                                           |  |  |
| routing and optimization strategy 3-6                    | 55 <b>g</b> = 15                                                       |  |  |
| routing options 2-13                                     | 0                                                                      |  |  |
| routing statistics 3-35                                  | S                                                                      |  |  |
| routability, checking 1-3                                | search and repair, filling notches and gaps                            |  |  |
| route guide                                              | during 4-49                                                            |  |  |
| creating 2-3 finding 2-4                                 | set_clock_tree_options command 2-9                                     |  |  |
| removing 2-5                                             | set_distributed_route command 2-19                                     |  |  |
| route_detail command 3-26                                | set_extraction_options command 4-37                                    |  |  |
| route_global command 3-24                                | set_ignored_layers command 2-11                                        |  |  |
| route_group command 3-2                                  | set_left_right_filler_rule command 4-30                                |  |  |
| route_group command 3-2 route_search_repair command 3-26 | set_net_aggressors command 2-18                                        |  |  |
| route spreadwires command 4-26                           | set_net_routing_rule command 2-9                                       |  |  |
| route_track command 3-25                                 | set_physical_signoff_options command 3-38,                             |  |  |
| route_track command 5-25                                 | 4-41                                                                   |  |  |
| route zrt eco command 3-34                               | set_preferred_routing_direction command 2-6                            |  |  |
| routing                                                  | set_route_mode_options command 2-2                                     |  |  |
| detail 3-26                                              | set_route_opt_strategy command 3-5                                     |  |  |
| ECO 3-34                                                 | set_route_options command 2-13                                         |  |  |

set\_route\_type command 2-13
set\_tlu\_plus\_files command 4-37
setting routing types 2-13
shielding nets 3-32
SolvNet
 accessing xiii
 documentation x
special nets, prerouting 3-2
standard cell filler
 inserting 4-29
 removing 4-32
 rules, defining 4-30
standard cell row, adding end caps 4-33

## Т

technology (.tf) file metal density rules 4-37 track assignment 3-25

## V

verify\_drc command 3-43 verify\_route command 3-46 vias inserting redundant 4-28 view, FILL 4-49

## W

well filler inserting 4-34 removing 4-35 wire spreading 4-26 wire widening 4-27

## Y

yield, optimizing
displaying critical area heat maps 4-25
performing wire spreading 4-26
performing wire widening 4-27